Semantic conventions for CICD metrics

Status: Development

CICD Metrics

The conventions described in this section are specific to Continuous Integration / Continuous Deployment (CICD) systems.

Disclaimer: These are initial CICD metrics and attributes but more may be added in the future.

Guidance on per pipeline run metrics

It might be useful to gather metrics specific to each pipeline run.
Examples of such metrics include:

  • host metrics like cpu, memory, disk of the worker on which a pipeline run executes
  • container metrics like cpu, memory requests and limits
  • runtime metrics of any processes executed as part of the pipeline run like JVM metrics

These metrics could be used to correlate build failures with environment issues like overload or out-of-memory. They could also be used in pipeline-level aggregations to inform adjustements of allocated worker resources.

When reporting host, container, runtime, and other metrics in CI/CD pipelines, instrumentation authors and application developers SHOULD use applicable CICD and VCS resource conventions and MAY also associate all or specific metrics with cicd.pipeline.run to correlate them with run information.

The cicd.pipeline.run entity identifies a pipeline run. Associating it with metrics inherently causes high cardinality and may increase costs with some metric storage backends. Thus, cicd.pipeline.run entity MUST be opt-in.

Metric: cicd.pipeline.run.duration

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
cicd.pipeline.run.durationHistogramsDuration of a pipeline run grouped by pipeline, state and result.Developmentcicd.pipeline

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
cicd.pipeline.nameDevelopmentRequiredstringThe human readable name of the pipeline within a CI/CD system.Build and Test; Lint; Deploy Go Project; deploy_to_environment
cicd.pipeline.run.stateDevelopmentRequiredstringThe pipeline run goes through these states during its lifecycle.pending; executing; finalizing
cicd.pipeline.resultDevelopmentConditionally Required [1]stringThe result of a pipeline run.success; failure; timeout; skipped
error.typeStableConditionally Required If and only if the pipeline run failed.stringDescribes a class of error the operation ended with. [2]timeout; java.net.UnknownHostException; server_certificate_invalid; 500

[1] cicd.pipeline.result: If and only if the pipeline run result has been set during that state.

[2] error.type: The error.type SHOULD be predictable, and SHOULD have low cardinality.

When error.type is set to a type (e.g., an exception type), its canonical class name identifying the type within the artifact SHOULD be used.

Instrumentations SHOULD document the list of errors they report.

The cardinality of error.type within one instrumentation library SHOULD be low. Telemetry consumers that aggregate data from multiple instrumentation libraries and applications should be prepared for error.type to have high cardinality at query time when no additional filters are applied.

If the operation has completed successfully, instrumentations SHOULD NOT set error.type.

If a specific domain defines its own set of error identifiers (such as HTTP or gRPC status codes), it’s RECOMMENDED to:

  • Use a domain-specific attribute
  • Set error.type to capture all errors, regardless of whether they are defined within the domain-specific set or not.

cicd.pipeline.result has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
cancellationThe pipeline run was cancelled, eg. by a user manually cancelling the pipeline run.Development
errorThe pipeline run failed due to an error in the CICD system, eg. due to the worker being killed.Development
failureThe pipeline run did not finish successfully, eg. due to a compile error or a failing test. Such failures are usually detected by non-zero exit codes of the tools executed in the pipeline run.Development
skipThe pipeline run was skipped, eg. due to a precondition not being met.Development
successThe pipeline run finished successfully.Development
timeoutA timeout caused the pipeline run to be interrupted.Development

cicd.pipeline.run.state has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
executingThe executing state spans the execution of any run tasks (eg. build, test).Development
finalizingThe finalizing state spans from when the run has finished executing (eg. cleanup of run resources).Development
pendingThe run pending state spans from the event triggering the pipeline run until the execution of the run starts (eg. time spent in a queue, provisioning agents, creating run resources).Development

error.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
_OTHERA fallback error value to be used when the instrumentation doesn’t define a custom value.Stable

Metric: cicd.pipeline.run.active

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
cicd.pipeline.run.activeUpDownCounter{run}The number of pipeline runs currently active in the system by state.Developmentcicd.pipeline

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
cicd.pipeline.nameDevelopmentRequiredstringThe human readable name of the pipeline within a CI/CD system.Build and Test; Lint; Deploy Go Project; deploy_to_environment
cicd.pipeline.run.stateDevelopmentRequiredstringThe pipeline run goes through these states during its lifecycle.pending; executing; finalizing

cicd.pipeline.run.state has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
executingThe executing state spans the execution of any run tasks (eg. build, test).Development
finalizingThe finalizing state spans from when the run has finished executing (eg. cleanup of run resources).Development
pendingThe run pending state spans from the event triggering the pipeline run until the execution of the run starts (eg. time spent in a queue, provisioning agents, creating run resources).Development

Metric: cicd.worker.count

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
cicd.worker.countUpDownCounter{count}The number of workers on the CICD system by state.Development

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
cicd.worker.stateDevelopmentRequiredstringThe state of a CICD worker / agent.idle; busy; down

cicd.worker.state has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
availableThe worker is not performing work for the CICD system. It is available to the CICD system to perform work on (online / idle). [1]Development
busyThe worker is performing work for the CICD system.Development
offlineThe worker is not available to the CICD system (disconnected / down).Development

[1]: Pipelines might have conditions on which workers they are able to run so not every worker might be available to every pipeline.

Metric: cicd.pipeline.run.errors

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
cicd.pipeline.run.errorsCounter{error}The number of errors encountered in pipeline runs (eg. compile, test failures). [1]Developmentcicd.pipeline

[1]: There might be errors in a pipeline run that are non fatal (eg. they are suppressed) or in a parallel stage multiple stages could have a fatal error. This means that this error count might not be the same as the count of metric cicd.pipeline.run.duration with run result failure.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
cicd.pipeline.nameDevelopmentRequiredstringThe human readable name of the pipeline within a CI/CD system.Build and Test; Lint; Deploy Go Project; deploy_to_environment
error.typeStableRequiredstringDescribes a class of error the operation ended with. [1]timeout; java.net.UnknownHostException; server_certificate_invalid; 500

[1] error.type: The error.type SHOULD be predictable, and SHOULD have low cardinality.

When error.type is set to a type (e.g., an exception type), its canonical class name identifying the type within the artifact SHOULD be used.

Instrumentations SHOULD document the list of errors they report.

The cardinality of error.type within one instrumentation library SHOULD be low. Telemetry consumers that aggregate data from multiple instrumentation libraries and applications should be prepared for error.type to have high cardinality at query time when no additional filters are applied.

If the operation has completed successfully, instrumentations SHOULD NOT set error.type.

If a specific domain defines its own set of error identifiers (such as HTTP or gRPC status codes), it’s RECOMMENDED to:

  • Use a domain-specific attribute
  • Set error.type to capture all errors, regardless of whether they are defined within the domain-specific set or not.

error.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
_OTHERA fallback error value to be used when the instrumentation doesn’t define a custom value.Stable

Metric: cicd.system.errors

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
cicd.system.errorsCounter{error}The number of errors in a component of the CICD system (eg. controller, scheduler, agent). [1]Development

[1]: Errors in pipeline run execution are explicitly excluded. Ie a test failure is not counted in this metric.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
cicd.system.componentDevelopmentRequiredstringThe name of a component of the CICD system.controller; scheduler; agent
error.typeStableRequiredstringDescribes a class of error the operation ended with. [1]timeout; java.net.UnknownHostException; server_certificate_invalid; 500

[1] error.type: The error.type SHOULD be predictable, and SHOULD have low cardinality.

When error.type is set to a type (e.g., an exception type), its canonical class name identifying the type within the artifact SHOULD be used.

Instrumentations SHOULD document the list of errors they report.

The cardinality of error.type within one instrumentation library SHOULD be low. Telemetry consumers that aggregate data from multiple instrumentation libraries and applications should be prepared for error.type to have high cardinality at query time when no additional filters are applied.

If the operation has completed successfully, instrumentations SHOULD NOT set error.type.

If a specific domain defines its own set of error identifiers (such as HTTP or gRPC status codes), it’s RECOMMENDED to:

  • Use a domain-specific attribute
  • Set error.type to capture all errors, regardless of whether they are defined within the domain-specific set or not.

error.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
_OTHERA fallback error value to be used when the instrumentation doesn’t define a custom value.Stable

VCS Metrics

The conventions described in this section are specific to Version Control Systems.

Disclaimer: These are initial VCS metrics and attributes but more may be added in the future.

Metric: vcs.change.count

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.change.countUpDownCounter{change}The number of changes (pull requests/merge requests/changelists) in a repository, categorized by their state (e.g. open or merged).Developmentvcs.repo

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.change.stateDevelopmentRequiredstringThe state of the change (pull request/merge request/changelist).open; closed; merged
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [1]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [2]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[2] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.change.state has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
closedClosed means the merge request has been closed without merging. This can happen for various reasons, such as the changes being deemed unnecessary, the issue being resolved in another way, or the author deciding to withdraw the request.Development
mergedMerged indicates that the change has been successfully integrated into the target codebase.Development
openOpen means the change is currently active and under review. It hasn’t been merged into the target branch yet, and it’s still possible to make changes or add comments.Development
wipWIP (work-in-progress, draft) means the change is still in progress and not yet ready for a full review. It might still undergo significant changes.Development

vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

Metric: vcs.change.duration

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.change.durationGaugesThe time duration a change (pull request/merge request/changelist) has been in a given state.Developmentvcs.repo

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.change.stateDevelopmentRequiredstringThe state of the change (pull request/merge request/changelist).open; closed; merged
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [2]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [3]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[2] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[3] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.change.state has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
closedClosed means the merge request has been closed without merging. This can happen for various reasons, such as the changes being deemed unnecessary, the issue being resolved in another way, or the author deciding to withdraw the request.Development
mergedMerged indicates that the change has been successfully integrated into the target codebase.Development
openOpen means the change is currently active and under review. It hasn’t been merged into the target branch yet, and it’s still possible to make changes or add comments.Development
wipWIP (work-in-progress, draft) means the change is still in progress and not yet ready for a full review. It might still undergo significant changes.Development

vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

Metric: vcs.change.time_to_approval

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.change.time_to_approvalGaugesThe amount of time since its creation it took a change (pull request/merge request/changelist) to get the first approval.Developmentvcs.repo; vcs.ref

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [2]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.ref.base.nameDevelopmentRecommendedstringThe name of the reference such as branch or tag in the repository. [3]my-feature-branch; tag-1-test
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [4]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket
vcs.ref.base.revisionDevelopmentOpt-InstringThe revision, literally revised version, The revision most often refers to a commit object in Git, or a revision number in SVN. [5]9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc; main; 123; HEAD
vcs.ref.head.revisionDevelopmentOpt-InstringThe revision, literally revised version, The revision most often refers to a commit object in Git, or a revision number in SVN. [6]9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc; main; 123; HEAD

[1] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[2] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[3] vcs.ref.base.name: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[4] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.

[5] vcs.ref.base.revision: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits. The revision can be a full hash value (see glossary), of the recorded change to a ref within a repository pointing to a commit commit object. It does not necessarily have to be a hash; it can simply define a revision number which is an integer that is monotonically increasing. In cases where it is identical to the ref.base.name, it SHOULD still be included. It is up to the implementer to decide which value to set as the revision based on the VCS system and situational context.

[6] vcs.ref.head.revision: head refers to where you are right now; the current reference at a given time.The revision can be a full hash value (see glossary), of the recorded change to a ref within a repository pointing to a commit commit object. It does not necessarily have to be a hash; it can simply define a revision number which is an integer that is monotonically increasing. In cases where it is identical to the ref.head.name, it SHOULD still be included. It is up to the implementer to decide which value to set as the revision based on the VCS system and situational context.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

Metric: vcs.change.time_to_merge

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.change.time_to_mergeGaugesThe amount of time since its creation it took a change (pull request/merge request/changelist) to get merged into the target(base) ref.Developmentvcs.repo; vcs.ref

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [2]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.ref.base.nameDevelopmentRecommendedstringThe name of the reference such as branch or tag in the repository. [3]my-feature-branch; tag-1-test
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [4]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket
vcs.ref.base.revisionDevelopmentOpt-InstringThe revision, literally revised version, The revision most often refers to a commit object in Git, or a revision number in SVN. [5]9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc; main; 123; HEAD
vcs.ref.head.revisionDevelopmentOpt-InstringThe revision, literally revised version, The revision most often refers to a commit object in Git, or a revision number in SVN. [6]9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc; main; 123; HEAD

[1] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[2] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[3] vcs.ref.base.name: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[4] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.

[5] vcs.ref.base.revision: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits. The revision can be a full hash value (see glossary), of the recorded change to a ref within a repository pointing to a commit commit object. It does not necessarily have to be a hash; it can simply define a revision number which is an integer that is monotonically increasing. In cases where it is identical to the ref.base.name, it SHOULD still be included. It is up to the implementer to decide which value to set as the revision based on the VCS system and situational context.

[6] vcs.ref.head.revision: head refers to where you are right now; the current reference at a given time.The revision can be a full hash value (see glossary), of the recorded change to a ref within a repository pointing to a commit commit object. It does not necessarily have to be a hash; it can simply define a revision number which is an integer that is monotonically increasing. In cases where it is identical to the ref.head.name, it SHOULD still be included. It is up to the implementer to decide which value to set as the revision based on the VCS system and situational context.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

Metric: vcs.repository.count

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.repository.countUpDownCounter{repository}The number of repositories in an organization.Development

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

Metric: vcs.ref.count

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.ref.countUpDownCounter{ref}The number of refs of type branch or tag in a repository.Developmentvcs.repo

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.ref.typeDevelopmentRequiredstringThe type of the reference in the repository.branch; tag
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [1]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [2]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[2] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

vcs.ref.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

Metric: vcs.ref.lines_delta

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.ref.lines_deltaGauge{line}The number of lines added/removed in a ref (branch) relative to the ref from the vcs.ref.base.name attribute. [1]Developmentvcs.repo

[1]: This metric should be reported for each vcs.line_change.type value. For example if a ref added 3 lines and removed 2 lines, instrumentation SHOULD report two measurements: 3 and 2 (both positive numbers). If number of lines added/removed should be calculated from the start of time, then vcs.ref.base.name SHOULD be set to an empty string.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.line_change.typeDevelopmentRequiredstringThe type of line change being measured on a branch or change.added; removed
vcs.ref.base.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.ref.base.typeDevelopmentRequiredstringThe type of the reference in the repository. [2]branch; tag
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [3]my-feature-branch; tag-1-test
vcs.ref.head.typeDevelopmentRequiredstringThe type of the reference in the repository. [4]branch; tag
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [5]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.change.idDevelopmentConditionally Required if a change is associate with the ref.stringThe ID of the change (pull request/merge request/changelist) if applicable. This is usually a unique (within repository) identifier generated by the VCS system.123
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [6]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.ref.base.name: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[2] vcs.ref.base.type: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[3] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[4] vcs.ref.head.type: head refers to where you are right now; the current reference at a given time.

[5] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[6] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.line_change.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
addedHow many lines were added.Development
removedHow many lines were removed.Development

vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

vcs.ref.base.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

vcs.ref.head.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

Metric: vcs.ref.revisions_delta

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.ref.revisions_deltaGauge{revision}The number of revisions (commits) a ref (branch) is ahead/behind the branch from the vcs.ref.base.name attribute. [1]Developmentvcs.repo

[1]: This metric should be reported for each vcs.revision_delta.direction value. For example if branch a is 3 commits behind and 2 commits ahead of trunk, instrumentation SHOULD report two measurements: 3 and 2 (both positive numbers) and vcs.ref.base.name is set to trunk.

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.ref.base.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.ref.base.typeDevelopmentRequiredstringThe type of the reference in the repository. [2]branch; tag
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [3]my-feature-branch; tag-1-test
vcs.ref.head.typeDevelopmentRequiredstringThe type of the reference in the repository. [4]branch; tag
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [5]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.revision_delta.directionDevelopmentRequiredstringThe type of revision comparison.ahead; behind
vcs.change.idDevelopmentConditionally Required if a change is associate with the ref.stringThe ID of the change (pull request/merge request/changelist) if applicable. This is usually a unique (within repository) identifier generated by the VCS system.123
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [6]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.ref.base.name: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[2] vcs.ref.base.type: base refers to the starting point of a change. For example, main would be the base reference of type branch if you’ve created a new reference of type branch from it and created new commits.

[3] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[4] vcs.ref.head.type: head refers to where you are right now; the current reference at a given time.

[5] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[6] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

vcs.ref.base.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

vcs.ref.head.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

vcs.revision_delta.direction has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
aheadHow many revisions the change is ahead of the target ref.Development
behindHow many revisions the change is behind the target ref.Development

Metric: vcs.ref.time

This metric is recommended.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.ref.timeGaugesTime a ref (branch) created from the default branch (trunk) has existed. The ref.type attribute will always be branch.Developmentvcs.repo

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.ref.head.nameDevelopmentRequiredstringThe name of the reference such as branch or tag in the repository. [1]my-feature-branch; tag-1-test
vcs.ref.head.typeDevelopmentRequiredstringThe type of the reference in the repository. [2]branch; tag
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [3]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [4]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.ref.head.name: head refers to where you are right now; the current reference at a given time.

[2] vcs.ref.head.type: head refers to where you are right now; the current reference at a given time.

[3] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[4] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment

vcs.ref.head.type has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
branchbranchDevelopment
tagtagDevelopment

Metric: vcs.contributor.count

This metric is opt-in.

NameInstrument TypeUnit (UCUM)DescriptionStabilityEntity Associations
vcs.contributor.countGauge{contributor}The number of unique contributors to a repository.Developmentvcs.repo

Attributes:

KeyStabilityRequirement LevelValue TypeDescriptionExample Values
vcs.repository.url.fullDevelopmentRequiredstringThe canonical URL of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser. [1]https://github.com/opentelemetry/open-telemetry-collector-contrib; https://gitlab.com/my-org/my-project/my-projects-project/repo
vcs.owner.nameDevelopmentRecommendedstringThe group owner within the version control system.my-org; myteam; business-unit
vcs.repository.nameDevelopmentRecommendedstringThe human readable name of the repository. It SHOULD NOT include any additional identifier like Group/SubGroup in GitLab or organization in GitHub. [2]semantic-conventions; my-cool-repo
vcs.provider.nameDevelopmentOpt-InstringThe name of the version control system provider.github; gitlab; gitea; bitbucket

[1] vcs.repository.url.full: In Git Version Control Systems, the canonical URL SHOULD NOT include the .git extension.

[2] vcs.repository.name: Due to it only being the name, it can clash with forks of the same repository if collecting telemetry across multiple orgs or groups in the same backends.


vcs.provider.name has the following list of well-known values. If one of them applies, then the respective value MUST be used; otherwise, a custom value MAY be used.

ValueDescriptionStability
bitbucketBitbucketDevelopment
giteaGiteaDevelopment
githubGitHubDevelopment
gitlabGitLabDevelopment