1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2025-01-24 03:47:19 +02:00
Sam Xie 6f048eb832
Add more semantic conventions for k8s as resource attributes (#1167)
* Add more semantic conventions for k8s

* Update CHANGELOG

Co-authored-by: Tyler Yahn <MrAlias@users.noreply.github.com>
2020-09-11 14:46:24 -07:00

224 lines
7.7 KiB
Go

// Copyright The OpenTelemetry Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package semconv
import "go.opentelemetry.io/otel/label"
// Semantic conventions for service resource attribute keys.
const (
// Name of the service.
ServiceNameKey = label.Key("service.name")
// A namespace for `service.name`. This needs to have meaning that helps
// to distinguish a group of services. For example, the team name that
// owns a group of services. `service.name` is expected to be unique
// within the same namespace.
ServiceNamespaceKey = label.Key("service.namespace")
// A unique identifier of the service instance. In conjunction with the
// `service.name` and `service.namespace` this must be unique.
ServiceInstanceIDKey = label.Key("service.instance.id")
// The version of the service API.
ServiceVersionKey = label.Key("service.version")
)
// Semantic conventions for telemetry SDK resource attribute keys.
const (
// The name of the telemetry SDK.
//
// The default OpenTelemetry SDK provided by the OpenTelemetry project
// MUST set telemetry.sdk.name to the value `opentelemetry`.
//
// If another SDK is used, this attribute MUST be set to the import path
// of that SDK's package.
//
// The value `opentelemetry` is reserved and MUST NOT be used by
// non-OpenTelemetry SDKs.
TelemetrySDKNameKey = label.Key("telemetry.sdk.name")
// The language of the telemetry SDK.
TelemetrySDKLanguageKey = label.Key("telemetry.sdk.language")
// The version string of the telemetry SDK.
TelemetrySDKVersionKey = label.Key("telemetry.sdk.version")
)
// Semantic conventions for telemetry SDK resource attributes.
var (
TelemetrySDKLanguageGo = TelemetrySDKLanguageKey.String("go")
)
// Semantic conventions for container resource attribute keys.
const (
// A uniquely identifying name for the Container.
ContainerNameKey = label.Key("container.name")
// Container ID, usually a UUID, as for example used to
// identify Docker containers. The UUID might be abbreviated.
ContainerIDKey = label.Key("container.id")
// Name of the image the container was built on.
ContainerImageNameKey = label.Key("container.image.name")
// Container image tag.
ContainerImageTagKey = label.Key("container.image.tag")
)
// Semantic conventions for Function-as-a-Service resource attribute keys.
const (
// A uniquely identifying name for the FaaS.
FaaSNameKey = label.Key("faas.name")
// The unique name of the function being executed.
FaaSIDKey = label.Key("faas.id")
// The version of the function being executed.
FaaSVersionKey = label.Key("faas.version")
// The execution environment identifier.
FaaSInstanceKey = label.Key("faas.instance")
)
// Semantic conventions for operating system process resource attribute keys.
const (
// Process identifier (PID).
ProcessPIDKey = label.Key("process.pid")
// The name of the process executable. On Linux based systems, can be
// set to the `Name` in `proc/[pid]/status`. On Windows, can be set to
// the base name of `GetProcessImageFileNameW`.
ProcessExecutableNameKey = label.Key("process.executable.name")
// The full path to the process executable. On Linux based systems, can
// be set to the target of `proc/[pid]/exe`. On Windows, can be set to
// the result of `GetProcessImageFileNameW`.
ProcessExecutablePathKey = label.Key("process.executable.path")
// The command used to launch the process (i.e. the command name). On
// Linux based systems, can be set to the zeroth string in
// `proc/[pid]/cmdline`. On Windows, can be set to the first parameter
// extracted from `GetCommandLineW`.
ProcessCommandKey = label.Key("process.command")
// The full command used to launch the process. The value can be either
// a list of strings representing the ordered list of arguments, or a
// single string representing the full command. On Linux based systems,
// can be set to the list of null-delimited strings extracted from
// `proc/[pid]/cmdline`. On Windows, can be set to the result of
// `GetCommandLineW`.
ProcessCommandLineKey = label.Key("process.command_line")
// The username of the user that owns the process.
ProcessOwnerKey = label.Key("process.owner")
)
// Semantic conventions for Kubernetes resource attribute keys.
const (
// A uniquely identifying name for the Kubernetes cluster. Kubernetes
// does not have cluster names as an internal concept so this may be
// set to any meaningful value within the environment. For example,
// GKE clusters have a name which can be used for this label.
K8SClusterNameKey = label.Key("k8s.cluster.name")
// The name of the namespace that the pod is running in.
K8SNamespaceNameKey = label.Key("k8s.namespace.name")
// The uid of the Pod.
K8SPodUIDKey = label.Key("k8s.pod.uid")
// The name of the pod.
K8SPodNameKey = label.Key("k8s.pod.name")
// The name of the Container in a Pod template.
K8SContainerNameKey = label.Key("k8s.container.name")
// The uid of the ReplicaSet.
K8SReplicaSetUIDKey = label.Key("k8s.replicaset.uid")
// The name of the ReplicaSet.
K8SReplicaSetNameKey = label.Key("k8s.replicaset.name")
// The uid of the Deployment.
K8SDeploymentUIDKey = label.Key("k8s.deployment.uid")
// The name of the deployment.
K8SDeploymentNameKey = label.Key("k8s.deployment.name")
// The uid of the StatefulSet.
K8SStatefulSetUIDKey = label.Key("k8s.statefulset.uid")
// The name of the StatefulSet.
K8SStatefulSetNameKey = label.Key("k8s.statefulset.name")
// The uid of the DaemonSet.
K8SDaemonSetUIDKey = label.Key("k8s.daemonset.uid")
// The name of the DaemonSet.
K8SDaemonSetNameKey = label.Key("k8s.daemonset.name")
// The uid of the Job.
K8SJobUIDKey = label.Key("k8s.job.uid")
// The name of the Job.
K8SJobNameKey = label.Key("k8s.job.name")
// The uid of the CronJob.
K8SCronJobUIDKey = label.Key("k8s.cronjob.uid")
// The name of the CronJob.
K8SCronJobNameKey = label.Key("k8s.cronjob.name")
)
// Semantic conventions for host resource attribute keys.
const (
// A uniquely identifying name for the host.
HostNameKey = label.Key("host.name")
// A hostname as returned by the 'hostname' command on host machine.
HostHostNameKey = label.Key("host.hostname")
// Unique host ID. For cloud environments this will be the instance ID.
HostIDKey = label.Key("host.id")
// Type of host. For cloud environments this will be the machine type.
HostTypeKey = label.Key("host.type")
// Name of the OS or VM image the host is running.
HostImageNameKey = label.Key("host.image.name")
// Identifier of the image the host is running.
HostImageIDKey = label.Key("host.image.id")
// Version of the image the host is running.
HostImageVersionKey = label.Key("host.image.version")
)
// Semantic conventions for cloud environment resource attribute keys.
const (
// Name of the cloud provider.
CloudProviderKey = label.Key("cloud.provider")
// The account ID from the cloud provider used for authorization.
CloudAccountIDKey = label.Key("cloud.account.id")
// Geographical region where this resource is.
CloudRegionKey = label.Key("cloud.region")
// Zone of the region where this resource is.
CloudZoneKey = label.Key("cloud.zone")
)
var (
CloudProviderAWS = CloudProviderKey.String("aws")
CloudProviderAzure = CloudProviderKey.String("azure")
CloudProviderGCP = CloudProviderKey.String("gcp")
)