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

Update database span name: clarify target and remove fallback #1069

Merged
merged 7 commits into from
May 28, 2024

Conversation

lmolkova
Copy link
Contributor

@lmolkova lmolkova commented May 24, 2024

Fixes #1045

Alternative to #1061

Changes

Clarifies that target depends on the operation and if target is not available, instrumentation should not fallback to other options.

E.g. for query like SELECT * FROM (VALUES (1, 'a'), (2, 'b'), (3, 'c')) AS t (id, name) that uses anonymous table, the span name should be SELECT and not SELECT {db.namespace}.

Merge requirement checklist

@lmolkova lmolkova requested review from a team May 24, 2024 00:06
docs/database/database-spans.md Outdated Show resolved Hide resolved
docs/database/database-spans.md Outdated Show resolved Hide resolved
@gregkalapos gregkalapos mentioned this pull request May 24, 2024
3 tasks
Copy link
Member

@gregkalapos gregkalapos left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice 👍

I'd maybe add 2 things here:

  • The example in the PR description with the anonymous table is very useful, I think that could be part of the spec.
  • The goal here is to avoid falling back to a less useful target, (that's also part of the PR description here). So my understanding is, we are ok to omit target in edge cases. But it's not really written into the spec and this PR doesn't really says that explicitly. I think it'd be worth adding it as well.

I had this in #1061:

A given instrumentation SHOULD strive for consistency in span names.


If certain queries lack this specific attribute, the instrumentation SHOULD use `{db.operation.name}` as the span name and omit `{target}`, 
rather than falling back to the next attribute in the [`{target}`](#target-placeholder) list.

(dropped the part which is different in this PR). Do we want to maybe add that part?

@lmolkova lmolkova force-pushed the db-span-name-no-fallback branch from 82ca546 to fca4393 Compare May 24, 2024 15:29
@lmolkova
Copy link
Contributor Author

@gregkalapos I updated the doc with your suggestion, lmk what you think

Copy link
Member

@gregkalapos gregkalapos left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@gregkalapos I updated the doc with your suggestion, lmk what you think

Thanks, lgtm.

@lmolkova lmolkova merged commit 6187071 into open-telemetry:main May 28, 2024
12 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

DB Span name format with alternating attributes
6 participants