-
Notifications
You must be signed in to change notification settings - Fork 933
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
add annotations for metrics #11285
add annotations for metrics #11285
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,88 @@ | ||||||
/* | ||||||
* Copyright The OpenTelemetry Authors | ||||||
* SPDX-License-Identifier: Apache-2.0 | ||||||
*/ | ||||||
|
||||||
package io.opentelemetry.instrumentation.api.incubator.annotations; | ||||||
|
||||||
import java.lang.annotation.ElementType; | ||||||
import java.lang.annotation.Retention; | ||||||
import java.lang.annotation.RetentionPolicy; | ||||||
import java.lang.annotation.Target; | ||||||
|
||||||
/** | ||||||
* This annotation creates a {@link io.opentelemetry.api.metrics.LongCounter Counter} instrument | ||||||
* recording the number of invocations of the annotated method or constructor. | ||||||
* | ||||||
* <p>By default, the Counter instrument will have the following attributes: | ||||||
* | ||||||
* <ul> | ||||||
* <li><b>code.namespace:</b> The fully qualified name of the class whose method is invoked. | ||||||
* <li><b>code.function:</b> The name of the annotated method, or "new" if the annotation is on a | ||||||
* constructor. | ||||||
* <li><b>exception.type:</b> This is only present if an Exception is thrown, and contains the | ||||||
* {@link Class#getCanonicalName() canonical name} of the Exception. | ||||||
* </ul> | ||||||
* | ||||||
* <p>Application developers can use this annotation to signal OpenTelemetry auto-instrumentation | ||||||
* that the Counter instrument should be created. | ||||||
* | ||||||
* <p>If you are a library developer, then probably you should NOT use this annotation, because it | ||||||
* is non-functional without the OpenTelemetry auto-instrumentation agent, or some other annotation | ||||||
* processor. | ||||||
*/ | ||||||
@Target({ElementType.METHOD, ElementType.CONSTRUCTOR}) | ||||||
@Retention(RetentionPolicy.RUNTIME) | ||||||
public @interface Counted { | ||||||
|
||||||
/** | ||||||
* Name of the Counter instrument. | ||||||
* | ||||||
* <p>The name should follow the instrument naming rule: <a | ||||||
* href="https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-naming-rule">https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-naming-rule</a> | ||||||
* | ||||||
* <p>The default name is {@code method.invocations.total}. | ||||||
*/ | ||||||
String value() default "method.invocations.total"; | ||||||
breedx-splk marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
|
||||||
/** | ||||||
* Description of the instrument. | ||||||
* | ||||||
* <p>Description strings should follow the instrument description rules: <a | ||||||
* href="https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-description">https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-description</a> | ||||||
*/ | ||||||
String description() default ""; | ||||||
|
||||||
/** | ||||||
* Unit of the instrument. | ||||||
* | ||||||
* <p>Unit strings should follow the instrument unit rules: <a | ||||||
* href="https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-unit">https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-unit</a> | ||||||
*/ | ||||||
String unit() default "1"; | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
See https://github.com/open-telemetry/opentelemetry-java-instrumentation/blob/main/instrumentation/runtime-telemetry/runtime-telemetry-java8/library/src/main/java/io/opentelemetry/instrumentation/runtimemetrics/java8/Classes.java#L55 for example of another instrument counting things. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. is the "{invocation}" a placeholder? I can not understand how it works from the reference, would you like to amplify a bit more on it? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This explains it in more detail: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/general/metrics.md#instrument-units |
||||||
|
||||||
/** | ||||||
* List of key-value pairs to supply additional attributes. | ||||||
* | ||||||
* <p>Example: | ||||||
* | ||||||
* <pre> | ||||||
* {@literal @}Counted( | ||||||
* additionalAttributes = { | ||||||
* "key1", "value1", | ||||||
* "key2", "value2", | ||||||
* }) | ||||||
* </pre> | ||||||
*/ | ||||||
String[] additionalAttributes() default {}; | ||||||
|
||||||
/** | ||||||
* Attribute name for the return value. | ||||||
* | ||||||
* <p>The name of the attribute for the return value of the method call. {@link Object#toString()} | ||||||
* will be called on the return value to convert it to a String. | ||||||
* | ||||||
* <p>By default, the instrument will not have an attribute with the return value. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think that this should also come with a warning that using this can very likely explode metric dimension cardinality. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's a good point, and MetricAttribute would have the same problem. |
||||||
*/ | ||||||
String returnValueAttribute() default ""; | ||||||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.instrumentation.api.incubator.annotations; | ||
|
||
import java.lang.annotation.ElementType; | ||
import java.lang.annotation.Retention; | ||
import java.lang.annotation.RetentionPolicy; | ||
import java.lang.annotation.Target; | ||
|
||
/** | ||
* This annotation marks that a parameter of a method or constructor annotated with {@link Timed} or | ||
* {@link Counted} should be added as an attribute to the instrument. | ||
* | ||
* <p>Application developers can use this annotation to signal OpenTelemetry auto-instrumentation | ||
* that the attribute should be created. | ||
* | ||
* <p>If you are a library developer, then probably you should NOT use this annotation, because it | ||
* is non-functional without the OpenTelemetry auto-instrumentation agent, or some other annotation | ||
* processor. | ||
*/ | ||
@Target(ElementType.PARAMETER) | ||
@Retention(RetentionPolicy.RUNTIME) | ||
public @interface MetricAttribute { | ||
|
||
/** | ||
* Optional name of the attribute. | ||
* | ||
* <p>If not specified and the code is compiled using the `{@code -parameters}` argument to | ||
* `javac`, the parameter name will be used instead. If the parameter name is not available, e.g., | ||
* because the code was not compiled with that flag, the attribute will be ignored. | ||
*/ | ||
String value() default ""; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.instrumentation.api.incubator.annotations; | ||
|
||
import java.lang.annotation.ElementType; | ||
import java.lang.annotation.Retention; | ||
import java.lang.annotation.RetentionPolicy; | ||
import java.lang.annotation.Target; | ||
import java.util.concurrent.TimeUnit; | ||
|
||
/** | ||
* This annotation creates a {@link io.opentelemetry.api.metrics.LongHistogram Histogram} instrument | ||
* observing the duration of invocations of the annotated method or constructor. | ||
* | ||
* <p>By default, the Histogram instrument will have the following attributes: | ||
* | ||
* <ul> | ||
* <li><b>code.namespace:</b> The fully qualified name of the class whose method is invoked. | ||
* <li><b>code.function:</b> The name of the annotated method, or "new" of the annotation is on a | ||
* constructor. | ||
* <li><b>exception.type:</b> This is only present if an Exception is thrown, and contains the | ||
* {@link Class#getCanonicalName canonical name} of the Exception. | ||
* </ul> | ||
* | ||
* <p>Application developers can use this annotation to signal OpenTelemetry auto-instrumentation | ||
* that the Histogram instrument should be created. | ||
* | ||
* <p>If you are a library developer, then probably you should NOT use this annotation, because it | ||
* is non-functional without the OpenTelemetry auto-instrumentation agent, or some other annotation | ||
* processor. | ||
*/ | ||
@Target({ElementType.METHOD, ElementType.CONSTRUCTOR}) | ||
@Retention(RetentionPolicy.RUNTIME) | ||
public @interface Timed { | ||
|
||
/** | ||
* Name of the Histogram instrument. | ||
* | ||
* <p>The name should follow the instrument naming rule: <a | ||
* href="https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-naming-rule">https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-naming-rule</a> | ||
* | ||
* <p>The default name is {@code method.invocations.duration}. | ||
*/ | ||
String value() default "method.invocations.duration"; | ||
|
||
/** | ||
* Description for the instrument. | ||
* | ||
* <p>Description strings should follow the instrument description rules: <a | ||
* href="https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-description">https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#instrument-description</a> | ||
*/ | ||
String description() default "1"; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Description should probably default to not set. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I aware that the "intrumentation-api-incubator" is not the good place to put the annotations. so I had moved them to "instrumentation-annotations" in another pr #11354. Despite it build failed due to the new instrumentation implementation, I think we can discuss on that one and close this one |
||
|
||
/** | ||
* The unit for the instrument. | ||
* | ||
* <p>Default is millis seconds. | ||
*/ | ||
TimeUnit unit() default TimeUnit.MILLISECONDS; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The default unit for durations in opentelemetry is seconds. This also means that this needs to record to a |
||
|
||
/** | ||
* List of key-value pairs to supply additional attributes. | ||
* | ||
* <p>Example: | ||
* | ||
* <pre> | ||
* {@literal @}Timed( | ||
* additionalAttributes = { | ||
* "key1", "value1", | ||
* "key2", "value2", | ||
* }) | ||
* </pre> | ||
*/ | ||
String[] attributes() default {}; | ||
|
||
/** | ||
* Attribute name for the return value. | ||
* | ||
* <p>The name of the attribute for the return value of the method call. {@link Object#toString()} | ||
* will be called on the return value to convert it to a String. | ||
* | ||
* <p>By default, the instrument will not have an attribute with the return value. | ||
*/ | ||
String returnValueAttribute() default ""; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For anyone wondering, yes these are consistent with the semantic convention registry. 👍🏻
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should I put the link in the code or copy the description from the reference?