Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Define whether instrumentations can emit non-event log records #4234

Closed
pellared opened this issue Sep 30, 2024 · 7 comments · Fixed by #4352
Closed

Define whether instrumentations can emit non-event log records #4234

pellared opened this issue Sep 30, 2024 · 7 comments · Fixed by #4352
Labels
area:api Cross language API specification issue sig-issue A specific SIG should look into this before discussing at the spec spec:logs Related to the specification/logs directory

Comments

@pellared
Copy link
Member

Imagine I'm instrumenting kafka:

  • there could be some events I'd emit - e.g. cluster leader is unreachable - which are documented in the semconv
  • there could also be things I just want to let my users know of via logs. E.g. certain configuration was picked, connection has dropped, etc. I could use 3rd party logging library, but why if I can use OTel logging API without adding a new dependency?

The library logs are emitted with is not relevant to users - they'd get the same logs if lib used 3rd party logger or OTel API. So I don't see why we should limit instrumentations from using OTel API to emit undocumented regular (but structured) logs.

Originally posted by @lmolkova in #4225 (comment)

@lmolkova lmolkova changed the title Define whether instrumentation libraries can emit non-event log records Define whether instrumentations can emit non-event log records Sep 30, 2024
@lmolkova
Copy link
Contributor

To add a bit of context: client libraries or infra components usually emit some logs using some non-OTel logging API.
If they are instrumented natively with OTel they need to have 2 dependencies - OTel and 3rd party logging lib.

While it's unlikely that existing libraries will replace their existing logging with OTel one, by providing user-facing logging API we allow future native instrumentations that use OTel for metrics and tracing to also use OTel logging API instead of adding a new dependency.

Before #4225 it was not possible.

@austinlparker
Copy link
Member

This actually seems to be two separate questions/issues -

  1. I am authoring an instrumentation library for Library Foo, that will be consumed as an external dependency of Library Foo (e.g., a library instrumentation that can be injected via zero-code instrumentation or as middleware that can be added at compile-time). How should I emit LogRecords from my instrumentation library that may not have semantic events defined?
  2. I am updating Library Bar to include native OpenTelemetry support. I currently use the standard logging library for my language. I need to emit semantic events as LogRecords, can I do so with my existing logging API, or do I need to use the OTel Logging API to emit those events and not do so for other messages?

In the first case, I think it is non-controversial to suggest that instrumentation libraries must only rely on OpenTelemetry APIs. I will eschew commentary on the second case for now.

@pellared pellared added area:api Cross language API specification issue spec:logs Related to the specification/logs directory labels Oct 1, 2024
@pellared
Copy link
Member Author

pellared commented Oct 1, 2024

Logs SIG meeting notes:
We decided to postpone this decision. We first need instrumentation libraries to emit events. We can later revisit if we need to emit log records as well (which are not events).

@pellared pellared added the triage:deciding:community-feedback Open to community discussion. If the community can provide sufficient reasoning, it may be accepted label Oct 1, 2024
@lmolkova
Copy link
Contributor

lmolkova commented Oct 1, 2024

To add to @austinlparker comment #4234 (comment) - from native instrumentation perspective I'm mostly interested in the case 3:

  1. I'm creating a new library that does not do any logging yet. It will use OTel tracing, metrics and events. It seems non-controversial that if I have any logging needs (not covered by events) I will also use OTel logging API. Otherwise, I'll need to pick a 3rd party logging facade which may require extra dependency.

@austinlparker
Copy link
Member

@lmolkova I considered adding that use case to the comment but left it off deliberately in order to keep the discussion focused. I do agree with you, though, it is an important use case to consider.

@github-actions github-actions bot added the triage:followup Needs follow up during triage label Oct 16, 2024
@danielgblanco danielgblanco added sig-issue A specific SIG should look into this before discussing at the spec and removed triage:deciding:community-feedback Open to community discussion. If the community can provide sufficient reasoning, it may be accepted triage:followup Needs follow up during triage labels Oct 21, 2024
@pellared pellared moved this to In progress in Logs SIG Dec 4, 2024
@pellared
Copy link
Member Author

pellared commented Dec 4, 2024

One of OTel Go prototypes for adding support for events makes emitting non-event log records "natural": open-telemetry/opentelemetry-go#6018

@pellared
Copy link
Member Author

pellared commented Jan 7, 2025

Another use case where emitting logs user-facing could be beneficial:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area:api Cross language API specification issue sig-issue A specific SIG should look into this before discussing at the spec spec:logs Related to the specification/logs directory
Projects
Status: Done
4 participants