Documentation ¶
Index ¶
- Constants
- func GetEntityEvents(oldMetadata, newMetadata map[metadataPkg.ResourceID]*KubernetesMetadata, ...) metadataPkg.EntityEventsSlice
- func GetMetadataUpdate(oldMetadata, newMetadata map[metadataPkg.ResourceID]*KubernetesMetadata) []*metadataPkg.MetadataUpdate
- func GetOTelNameFromKind(kind string) string
- func GetOTelUIDFromKind(kind string) string
- func MergeKubernetesMetadataMaps(maps ...map[metadataPkg.ResourceID]*KubernetesMetadata) map[metadataPkg.ResourceID]*KubernetesMetadata
- func Meter(settings component.TelemetrySettings) metric.Meter
- func Tracer(settings component.TelemetrySettings) trace.Tracer
- func TransformObjectMeta(om v1.ObjectMeta) v1.ObjectMeta
- func WithStartTime(startTime pcommon.Timestamp) metricBuilderOption
- type KubernetesMetadata
- type MetricConfig
- type MetricsBuilder
- func (mb *MetricsBuilder) Emit(rmo ...ResourceMetricsOption) pmetric.Metrics
- func (mb *MetricsBuilder) EmitForResource(rmo ...ResourceMetricsOption)
- func (mb *MetricsBuilder) NewResourceBuilder() *ResourceBuilder
- func (mb *MetricsBuilder) RecordK8sContainerCPULimitDataPoint(ts pcommon.Timestamp, val float64)
- func (mb *MetricsBuilder) RecordK8sContainerCPURequestDataPoint(ts pcommon.Timestamp, val float64)
- func (mb *MetricsBuilder) RecordK8sContainerEphemeralstorageLimitDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerEphemeralstorageRequestDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerMemoryLimitDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerMemoryRequestDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerReadyDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerRestartsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerStorageLimitDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sContainerStorageRequestDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sCronjobActiveJobsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDaemonsetCurrentScheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDaemonsetDesiredScheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDaemonsetMisscheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDaemonsetReadyNodesDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDeploymentAvailableDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sDeploymentDesiredDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sHpaCurrentReplicasDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sHpaDesiredReplicasDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sHpaMaxReplicasDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sHpaMinReplicasDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sJobActivePodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sJobDesiredSuccessfulPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sJobFailedPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sJobMaxParallelPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sJobSuccessfulPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sNamespacePhaseDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sNodeConditionDataPoint(ts pcommon.Timestamp, val int64, conditionAttributeValue string)
- func (mb *MetricsBuilder) RecordK8sPodPhaseDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sPodStatusReasonDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sReplicasetAvailableDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sReplicasetDesiredDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sReplicationControllerAvailableDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sReplicationControllerDesiredDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sResourceQuotaHardLimitDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
- func (mb *MetricsBuilder) RecordK8sResourceQuotaUsedDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
- func (mb *MetricsBuilder) RecordK8sStatefulsetCurrentPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sStatefulsetDesiredPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sStatefulsetReadyPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordK8sStatefulsetUpdatedPodsDataPoint(ts pcommon.Timestamp, val int64)
- func (mb *MetricsBuilder) RecordOpenshiftAppliedclusterquotaLimitDataPoint(ts pcommon.Timestamp, val int64, k8sNamespaceNameAttributeValue string, ...)
- func (mb *MetricsBuilder) RecordOpenshiftAppliedclusterquotaUsedDataPoint(ts pcommon.Timestamp, val int64, k8sNamespaceNameAttributeValue string, ...)
- func (mb *MetricsBuilder) RecordOpenshiftClusterquotaLimitDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
- func (mb *MetricsBuilder) RecordOpenshiftClusterquotaUsedDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
- func (mb *MetricsBuilder) Reset(options ...metricBuilderOption)
- type MetricsBuilderConfig
- type MetricsConfig
- type ResourceAttributeConfig
- type ResourceAttributesConfig
- type ResourceBuilder
- func (rb *ResourceBuilder) Emit() pcommon.Resource
- func (rb *ResourceBuilder) SetContainerID(val string)
- func (rb *ResourceBuilder) SetContainerImageName(val string)
- func (rb *ResourceBuilder) SetContainerImageTag(val string)
- func (rb *ResourceBuilder) SetK8sContainerName(val string)
- func (rb *ResourceBuilder) SetK8sCronjobName(val string)
- func (rb *ResourceBuilder) SetK8sCronjobUID(val string)
- func (rb *ResourceBuilder) SetK8sDaemonsetName(val string)
- func (rb *ResourceBuilder) SetK8sDaemonsetUID(val string)
- func (rb *ResourceBuilder) SetK8sDeploymentName(val string)
- func (rb *ResourceBuilder) SetK8sDeploymentUID(val string)
- func (rb *ResourceBuilder) SetK8sHpaName(val string)
- func (rb *ResourceBuilder) SetK8sHpaUID(val string)
- func (rb *ResourceBuilder) SetK8sJobName(val string)
- func (rb *ResourceBuilder) SetK8sJobUID(val string)
- func (rb *ResourceBuilder) SetK8sKubeletVersion(val string)
- func (rb *ResourceBuilder) SetK8sKubeproxyVersion(val string)
- func (rb *ResourceBuilder) SetK8sNamespaceName(val string)
- func (rb *ResourceBuilder) SetK8sNamespaceUID(val string)
- func (rb *ResourceBuilder) SetK8sNodeName(val string)
- func (rb *ResourceBuilder) SetK8sNodeUID(val string)
- func (rb *ResourceBuilder) SetK8sPodName(val string)
- func (rb *ResourceBuilder) SetK8sPodQosClass(val string)
- func (rb *ResourceBuilder) SetK8sPodUID(val string)
- func (rb *ResourceBuilder) SetK8sReplicasetName(val string)
- func (rb *ResourceBuilder) SetK8sReplicasetUID(val string)
- func (rb *ResourceBuilder) SetK8sReplicationcontrollerName(val string)
- func (rb *ResourceBuilder) SetK8sReplicationcontrollerUID(val string)
- func (rb *ResourceBuilder) SetK8sResourcequotaName(val string)
- func (rb *ResourceBuilder) SetK8sResourcequotaUID(val string)
- func (rb *ResourceBuilder) SetK8sStatefulsetName(val string)
- func (rb *ResourceBuilder) SetK8sStatefulsetUID(val string)
- func (rb *ResourceBuilder) SetOpenshiftClusterquotaName(val string)
- func (rb *ResourceBuilder) SetOpenshiftClusterquotaUID(val string)
- type ResourceMetricsOption
- type Store
Constants ¶
const ( Type = "k8s_cluster" MetricsStability = component.StabilityLevelBeta LogsStability = component.StabilityLevelDevelopment )
Variables ¶
This section is empty.
Functions ¶
func GetEntityEvents ¶ added in v0.82.0
func GetEntityEvents(oldMetadata, newMetadata map[metadataPkg.ResourceID]*KubernetesMetadata, timestamp pcommon.Timestamp) metadataPkg.EntityEventsSlice
GetEntityEvents processes metadata updates and returns entity events that describe the metadata changes.
func GetMetadataUpdate ¶
func GetMetadataUpdate(oldMetadata, newMetadata map[metadataPkg.ResourceID]*KubernetesMetadata) []*metadataPkg.MetadataUpdate
GetMetadataUpdate processes metadata updates and returns a map of a delta of metadata mapped to each resource.
func GetOTelNameFromKind ¶
func GetOTelUIDFromKind ¶
func MergeKubernetesMetadataMaps ¶
func MergeKubernetesMetadataMaps(maps ...map[metadataPkg.ResourceID]*KubernetesMetadata) map[metadataPkg.ResourceID]*KubernetesMetadata
mergeKubernetesMetadataMaps merges maps of string (resource id) to KubernetesMetadata into a single map.
func TransformObjectMeta ¶ added in v0.80.0
func TransformObjectMeta(om v1.ObjectMeta) v1.ObjectMeta
func WithStartTime ¶ added in v0.82.0
WithStartTime sets startTime on the metrics builder.
Types ¶
type KubernetesMetadata ¶
type KubernetesMetadata struct { // The type of the entity, e.g. k8s.pod EntityType string // resourceIDKey is the label key of UID label for the resource. ResourceIDKey string // resourceID is the Kubernetes UID of the resource. In case of // containers, this value is the container id. ResourceID metadataPkg.ResourceID // metadata is a set of key-value pairs that describe a resource. Metadata map[string]string }
KubernetesMetadata associates a resource to a set of properties.
func GetGenericMetadata ¶
func GetGenericMetadata(om *v1.ObjectMeta, resourceType string) *KubernetesMetadata
GetGenericMetadata is responsible for collecting metadata from K8s resources that live on v1.ObjectMeta.
type MetricConfig ¶ added in v0.82.0
type MetricConfig struct { Enabled bool `mapstructure:"enabled"` // contains filtered or unexported fields }
MetricConfig provides common config for a particular metric.
type MetricsBuilder ¶ added in v0.82.0
type MetricsBuilder struct {
// contains filtered or unexported fields
}
MetricsBuilder provides an interface for scrapers to report metrics while taking care of all the transformations required to produce metric representation defined in metadata and user config.
func NewMetricsBuilder ¶ added in v0.82.0
func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSettings, options ...metricBuilderOption) *MetricsBuilder
func (*MetricsBuilder) Emit ¶ added in v0.82.0
func (mb *MetricsBuilder) Emit(rmo ...ResourceMetricsOption) pmetric.Metrics
Emit returns all the metrics accumulated by the metrics builder and updates the internal state to be ready for recording another set of metrics. This function will be responsible for applying all the transformations required to produce metric representation defined in metadata and user config, e.g. delta or cumulative.
func (*MetricsBuilder) EmitForResource ¶ added in v0.82.0
func (mb *MetricsBuilder) EmitForResource(rmo ...ResourceMetricsOption)
EmitForResource saves all the generated metrics under a new resource and updates the internal state to be ready for recording another set of data points as part of another resource. This function can be helpful when one scraper needs to emit metrics from several resources. Otherwise calling this function is not required, just `Emit` function can be called instead. Resource attributes should be provided as ResourceMetricsOption arguments.
func (*MetricsBuilder) NewResourceBuilder ¶ added in v0.83.0
func (mb *MetricsBuilder) NewResourceBuilder() *ResourceBuilder
NewResourceBuilder returns a new resource builder that should be used to build a resource associated with for the emitted metrics.
func (*MetricsBuilder) RecordK8sContainerCPULimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerCPULimitDataPoint(ts pcommon.Timestamp, val float64)
RecordK8sContainerCPULimitDataPoint adds a data point to k8s.container.cpu_limit metric.
func (*MetricsBuilder) RecordK8sContainerCPURequestDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerCPURequestDataPoint(ts pcommon.Timestamp, val float64)
RecordK8sContainerCPURequestDataPoint adds a data point to k8s.container.cpu_request metric.
func (*MetricsBuilder) RecordK8sContainerEphemeralstorageLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerEphemeralstorageLimitDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerEphemeralstorageLimitDataPoint adds a data point to k8s.container.ephemeralstorage_limit metric.
func (*MetricsBuilder) RecordK8sContainerEphemeralstorageRequestDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerEphemeralstorageRequestDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerEphemeralstorageRequestDataPoint adds a data point to k8s.container.ephemeralstorage_request metric.
func (*MetricsBuilder) RecordK8sContainerMemoryLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerMemoryLimitDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerMemoryLimitDataPoint adds a data point to k8s.container.memory_limit metric.
func (*MetricsBuilder) RecordK8sContainerMemoryRequestDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerMemoryRequestDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerMemoryRequestDataPoint adds a data point to k8s.container.memory_request metric.
func (*MetricsBuilder) RecordK8sContainerReadyDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerReadyDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerReadyDataPoint adds a data point to k8s.container.ready metric.
func (*MetricsBuilder) RecordK8sContainerRestartsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerRestartsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerRestartsDataPoint adds a data point to k8s.container.restarts metric.
func (*MetricsBuilder) RecordK8sContainerStorageLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerStorageLimitDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerStorageLimitDataPoint adds a data point to k8s.container.storage_limit metric.
func (*MetricsBuilder) RecordK8sContainerStorageRequestDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sContainerStorageRequestDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sContainerStorageRequestDataPoint adds a data point to k8s.container.storage_request metric.
func (*MetricsBuilder) RecordK8sCronjobActiveJobsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sCronjobActiveJobsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sCronjobActiveJobsDataPoint adds a data point to k8s.cronjob.active_jobs metric.
func (*MetricsBuilder) RecordK8sDaemonsetCurrentScheduledNodesDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDaemonsetCurrentScheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDaemonsetCurrentScheduledNodesDataPoint adds a data point to k8s.daemonset.current_scheduled_nodes metric.
func (*MetricsBuilder) RecordK8sDaemonsetDesiredScheduledNodesDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDaemonsetDesiredScheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDaemonsetDesiredScheduledNodesDataPoint adds a data point to k8s.daemonset.desired_scheduled_nodes metric.
func (*MetricsBuilder) RecordK8sDaemonsetMisscheduledNodesDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDaemonsetMisscheduledNodesDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDaemonsetMisscheduledNodesDataPoint adds a data point to k8s.daemonset.misscheduled_nodes metric.
func (*MetricsBuilder) RecordK8sDaemonsetReadyNodesDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDaemonsetReadyNodesDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDaemonsetReadyNodesDataPoint adds a data point to k8s.daemonset.ready_nodes metric.
func (*MetricsBuilder) RecordK8sDeploymentAvailableDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDeploymentAvailableDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDeploymentAvailableDataPoint adds a data point to k8s.deployment.available metric.
func (*MetricsBuilder) RecordK8sDeploymentDesiredDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sDeploymentDesiredDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sDeploymentDesiredDataPoint adds a data point to k8s.deployment.desired metric.
func (*MetricsBuilder) RecordK8sHpaCurrentReplicasDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sHpaCurrentReplicasDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sHpaCurrentReplicasDataPoint adds a data point to k8s.hpa.current_replicas metric.
func (*MetricsBuilder) RecordK8sHpaDesiredReplicasDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sHpaDesiredReplicasDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sHpaDesiredReplicasDataPoint adds a data point to k8s.hpa.desired_replicas metric.
func (*MetricsBuilder) RecordK8sHpaMaxReplicasDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sHpaMaxReplicasDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sHpaMaxReplicasDataPoint adds a data point to k8s.hpa.max_replicas metric.
func (*MetricsBuilder) RecordK8sHpaMinReplicasDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sHpaMinReplicasDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sHpaMinReplicasDataPoint adds a data point to k8s.hpa.min_replicas metric.
func (*MetricsBuilder) RecordK8sJobActivePodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sJobActivePodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sJobActivePodsDataPoint adds a data point to k8s.job.active_pods metric.
func (*MetricsBuilder) RecordK8sJobDesiredSuccessfulPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sJobDesiredSuccessfulPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sJobDesiredSuccessfulPodsDataPoint adds a data point to k8s.job.desired_successful_pods metric.
func (*MetricsBuilder) RecordK8sJobFailedPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sJobFailedPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sJobFailedPodsDataPoint adds a data point to k8s.job.failed_pods metric.
func (*MetricsBuilder) RecordK8sJobMaxParallelPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sJobMaxParallelPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sJobMaxParallelPodsDataPoint adds a data point to k8s.job.max_parallel_pods metric.
func (*MetricsBuilder) RecordK8sJobSuccessfulPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sJobSuccessfulPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sJobSuccessfulPodsDataPoint adds a data point to k8s.job.successful_pods metric.
func (*MetricsBuilder) RecordK8sNamespacePhaseDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sNamespacePhaseDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sNamespacePhaseDataPoint adds a data point to k8s.namespace.phase metric.
func (*MetricsBuilder) RecordK8sNodeConditionDataPoint ¶ added in v0.89.0
func (mb *MetricsBuilder) RecordK8sNodeConditionDataPoint(ts pcommon.Timestamp, val int64, conditionAttributeValue string)
RecordK8sNodeConditionDataPoint adds a data point to k8s.node.condition metric.
func (*MetricsBuilder) RecordK8sPodPhaseDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sPodPhaseDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sPodPhaseDataPoint adds a data point to k8s.pod.phase metric.
func (*MetricsBuilder) RecordK8sPodStatusReasonDataPoint ¶ added in v0.85.0
func (mb *MetricsBuilder) RecordK8sPodStatusReasonDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sPodStatusReasonDataPoint adds a data point to k8s.pod.status_reason metric.
func (*MetricsBuilder) RecordK8sReplicasetAvailableDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sReplicasetAvailableDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sReplicasetAvailableDataPoint adds a data point to k8s.replicaset.available metric.
func (*MetricsBuilder) RecordK8sReplicasetDesiredDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sReplicasetDesiredDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sReplicasetDesiredDataPoint adds a data point to k8s.replicaset.desired metric.
func (*MetricsBuilder) RecordK8sReplicationControllerAvailableDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sReplicationControllerAvailableDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sReplicationControllerAvailableDataPoint adds a data point to k8s.replication_controller.available metric.
func (*MetricsBuilder) RecordK8sReplicationControllerDesiredDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sReplicationControllerDesiredDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sReplicationControllerDesiredDataPoint adds a data point to k8s.replication_controller.desired metric.
func (*MetricsBuilder) RecordK8sResourceQuotaHardLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sResourceQuotaHardLimitDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
RecordK8sResourceQuotaHardLimitDataPoint adds a data point to k8s.resource_quota.hard_limit metric.
func (*MetricsBuilder) RecordK8sResourceQuotaUsedDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sResourceQuotaUsedDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
RecordK8sResourceQuotaUsedDataPoint adds a data point to k8s.resource_quota.used metric.
func (*MetricsBuilder) RecordK8sStatefulsetCurrentPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sStatefulsetCurrentPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sStatefulsetCurrentPodsDataPoint adds a data point to k8s.statefulset.current_pods metric.
func (*MetricsBuilder) RecordK8sStatefulsetDesiredPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sStatefulsetDesiredPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sStatefulsetDesiredPodsDataPoint adds a data point to k8s.statefulset.desired_pods metric.
func (*MetricsBuilder) RecordK8sStatefulsetReadyPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sStatefulsetReadyPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sStatefulsetReadyPodsDataPoint adds a data point to k8s.statefulset.ready_pods metric.
func (*MetricsBuilder) RecordK8sStatefulsetUpdatedPodsDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordK8sStatefulsetUpdatedPodsDataPoint(ts pcommon.Timestamp, val int64)
RecordK8sStatefulsetUpdatedPodsDataPoint adds a data point to k8s.statefulset.updated_pods metric.
func (*MetricsBuilder) RecordOpenshiftAppliedclusterquotaLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordOpenshiftAppliedclusterquotaLimitDataPoint(ts pcommon.Timestamp, val int64, k8sNamespaceNameAttributeValue string, resourceAttributeValue string)
RecordOpenshiftAppliedclusterquotaLimitDataPoint adds a data point to openshift.appliedclusterquota.limit metric.
func (*MetricsBuilder) RecordOpenshiftAppliedclusterquotaUsedDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordOpenshiftAppliedclusterquotaUsedDataPoint(ts pcommon.Timestamp, val int64, k8sNamespaceNameAttributeValue string, resourceAttributeValue string)
RecordOpenshiftAppliedclusterquotaUsedDataPoint adds a data point to openshift.appliedclusterquota.used metric.
func (*MetricsBuilder) RecordOpenshiftClusterquotaLimitDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordOpenshiftClusterquotaLimitDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
RecordOpenshiftClusterquotaLimitDataPoint adds a data point to openshift.clusterquota.limit metric.
func (*MetricsBuilder) RecordOpenshiftClusterquotaUsedDataPoint ¶ added in v0.82.0
func (mb *MetricsBuilder) RecordOpenshiftClusterquotaUsedDataPoint(ts pcommon.Timestamp, val int64, resourceAttributeValue string)
RecordOpenshiftClusterquotaUsedDataPoint adds a data point to openshift.clusterquota.used metric.
func (*MetricsBuilder) Reset ¶ added in v0.82.0
func (mb *MetricsBuilder) Reset(options ...metricBuilderOption)
Reset resets metrics builder to its initial state. It should be used when external metrics source is restarted, and metrics builder should update its startTime and reset it's internal state accordingly.
type MetricsBuilderConfig ¶ added in v0.82.0
type MetricsBuilderConfig struct { Metrics MetricsConfig `mapstructure:"metrics"` ResourceAttributes ResourceAttributesConfig `mapstructure:"resource_attributes"` }
MetricsBuilderConfig is a configuration for k8s_cluster metrics builder.
func DefaultMetricsBuilderConfig ¶ added in v0.82.0
func DefaultMetricsBuilderConfig() MetricsBuilderConfig
type MetricsConfig ¶ added in v0.82.0
type MetricsConfig struct { K8sContainerCPULimit MetricConfig `mapstructure:"k8s.container.cpu_limit"` K8sContainerCPURequest MetricConfig `mapstructure:"k8s.container.cpu_request"` K8sContainerEphemeralstorageLimit MetricConfig `mapstructure:"k8s.container.ephemeralstorage_limit"` K8sContainerEphemeralstorageRequest MetricConfig `mapstructure:"k8s.container.ephemeralstorage_request"` K8sContainerMemoryLimit MetricConfig `mapstructure:"k8s.container.memory_limit"` K8sContainerMemoryRequest MetricConfig `mapstructure:"k8s.container.memory_request"` K8sContainerReady MetricConfig `mapstructure:"k8s.container.ready"` K8sContainerRestarts MetricConfig `mapstructure:"k8s.container.restarts"` K8sContainerStorageLimit MetricConfig `mapstructure:"k8s.container.storage_limit"` K8sContainerStorageRequest MetricConfig `mapstructure:"k8s.container.storage_request"` K8sCronjobActiveJobs MetricConfig `mapstructure:"k8s.cronjob.active_jobs"` K8sDaemonsetCurrentScheduledNodes MetricConfig `mapstructure:"k8s.daemonset.current_scheduled_nodes"` K8sDaemonsetDesiredScheduledNodes MetricConfig `mapstructure:"k8s.daemonset.desired_scheduled_nodes"` K8sDaemonsetMisscheduledNodes MetricConfig `mapstructure:"k8s.daemonset.misscheduled_nodes"` K8sDaemonsetReadyNodes MetricConfig `mapstructure:"k8s.daemonset.ready_nodes"` K8sDeploymentAvailable MetricConfig `mapstructure:"k8s.deployment.available"` K8sDeploymentDesired MetricConfig `mapstructure:"k8s.deployment.desired"` K8sHpaCurrentReplicas MetricConfig `mapstructure:"k8s.hpa.current_replicas"` K8sHpaDesiredReplicas MetricConfig `mapstructure:"k8s.hpa.desired_replicas"` K8sHpaMaxReplicas MetricConfig `mapstructure:"k8s.hpa.max_replicas"` K8sHpaMinReplicas MetricConfig `mapstructure:"k8s.hpa.min_replicas"` K8sJobActivePods MetricConfig `mapstructure:"k8s.job.active_pods"` K8sJobDesiredSuccessfulPods MetricConfig `mapstructure:"k8s.job.desired_successful_pods"` K8sJobFailedPods MetricConfig `mapstructure:"k8s.job.failed_pods"` K8sJobMaxParallelPods MetricConfig `mapstructure:"k8s.job.max_parallel_pods"` K8sJobSuccessfulPods MetricConfig `mapstructure:"k8s.job.successful_pods"` K8sNamespacePhase MetricConfig `mapstructure:"k8s.namespace.phase"` K8sNodeCondition MetricConfig `mapstructure:"k8s.node.condition"` K8sPodPhase MetricConfig `mapstructure:"k8s.pod.phase"` K8sPodStatusReason MetricConfig `mapstructure:"k8s.pod.status_reason"` K8sReplicasetAvailable MetricConfig `mapstructure:"k8s.replicaset.available"` K8sReplicasetDesired MetricConfig `mapstructure:"k8s.replicaset.desired"` K8sReplicationControllerAvailable MetricConfig `mapstructure:"k8s.replication_controller.available"` K8sReplicationControllerDesired MetricConfig `mapstructure:"k8s.replication_controller.desired"` K8sResourceQuotaHardLimit MetricConfig `mapstructure:"k8s.resource_quota.hard_limit"` K8sResourceQuotaUsed MetricConfig `mapstructure:"k8s.resource_quota.used"` K8sStatefulsetCurrentPods MetricConfig `mapstructure:"k8s.statefulset.current_pods"` K8sStatefulsetDesiredPods MetricConfig `mapstructure:"k8s.statefulset.desired_pods"` K8sStatefulsetReadyPods MetricConfig `mapstructure:"k8s.statefulset.ready_pods"` K8sStatefulsetUpdatedPods MetricConfig `mapstructure:"k8s.statefulset.updated_pods"` OpenshiftAppliedclusterquotaLimit MetricConfig `mapstructure:"openshift.appliedclusterquota.limit"` OpenshiftAppliedclusterquotaUsed MetricConfig `mapstructure:"openshift.appliedclusterquota.used"` OpenshiftClusterquotaLimit MetricConfig `mapstructure:"openshift.clusterquota.limit"` OpenshiftClusterquotaUsed MetricConfig `mapstructure:"openshift.clusterquota.used"` }
MetricsConfig provides config for k8s_cluster metrics.
func DefaultMetricsConfig ¶ added in v0.82.0
func DefaultMetricsConfig() MetricsConfig
type ResourceAttributeConfig ¶ added in v0.82.0
type ResourceAttributeConfig struct { Enabled bool `mapstructure:"enabled"` // contains filtered or unexported fields }
ResourceAttributeConfig provides common config for a particular resource attribute.
type ResourceAttributesConfig ¶ added in v0.82.0
type ResourceAttributesConfig struct { ContainerID ResourceAttributeConfig `mapstructure:"container.id"` ContainerImageName ResourceAttributeConfig `mapstructure:"container.image.name"` ContainerImageTag ResourceAttributeConfig `mapstructure:"container.image.tag"` K8sContainerName ResourceAttributeConfig `mapstructure:"k8s.container.name"` K8sCronjobName ResourceAttributeConfig `mapstructure:"k8s.cronjob.name"` K8sCronjobUID ResourceAttributeConfig `mapstructure:"k8s.cronjob.uid"` K8sDaemonsetName ResourceAttributeConfig `mapstructure:"k8s.daemonset.name"` K8sDaemonsetUID ResourceAttributeConfig `mapstructure:"k8s.daemonset.uid"` K8sDeploymentName ResourceAttributeConfig `mapstructure:"k8s.deployment.name"` K8sDeploymentUID ResourceAttributeConfig `mapstructure:"k8s.deployment.uid"` K8sHpaName ResourceAttributeConfig `mapstructure:"k8s.hpa.name"` K8sHpaUID ResourceAttributeConfig `mapstructure:"k8s.hpa.uid"` K8sJobName ResourceAttributeConfig `mapstructure:"k8s.job.name"` K8sJobUID ResourceAttributeConfig `mapstructure:"k8s.job.uid"` K8sKubeletVersion ResourceAttributeConfig `mapstructure:"k8s.kubelet.version"` K8sKubeproxyVersion ResourceAttributeConfig `mapstructure:"k8s.kubeproxy.version"` K8sNamespaceName ResourceAttributeConfig `mapstructure:"k8s.namespace.name"` K8sNamespaceUID ResourceAttributeConfig `mapstructure:"k8s.namespace.uid"` K8sNodeName ResourceAttributeConfig `mapstructure:"k8s.node.name"` K8sNodeUID ResourceAttributeConfig `mapstructure:"k8s.node.uid"` K8sPodName ResourceAttributeConfig `mapstructure:"k8s.pod.name"` K8sPodQosClass ResourceAttributeConfig `mapstructure:"k8s.pod.qos_class"` K8sPodUID ResourceAttributeConfig `mapstructure:"k8s.pod.uid"` K8sReplicasetName ResourceAttributeConfig `mapstructure:"k8s.replicaset.name"` K8sReplicasetUID ResourceAttributeConfig `mapstructure:"k8s.replicaset.uid"` K8sReplicationcontrollerName ResourceAttributeConfig `mapstructure:"k8s.replicationcontroller.name"` K8sReplicationcontrollerUID ResourceAttributeConfig `mapstructure:"k8s.replicationcontroller.uid"` K8sResourcequotaName ResourceAttributeConfig `mapstructure:"k8s.resourcequota.name"` K8sResourcequotaUID ResourceAttributeConfig `mapstructure:"k8s.resourcequota.uid"` K8sStatefulsetName ResourceAttributeConfig `mapstructure:"k8s.statefulset.name"` K8sStatefulsetUID ResourceAttributeConfig `mapstructure:"k8s.statefulset.uid"` OpenshiftClusterquotaName ResourceAttributeConfig `mapstructure:"openshift.clusterquota.name"` OpenshiftClusterquotaUID ResourceAttributeConfig `mapstructure:"openshift.clusterquota.uid"` }
ResourceAttributesConfig provides config for k8s_cluster resource attributes.
func DefaultResourceAttributesConfig ¶ added in v0.82.0
func DefaultResourceAttributesConfig() ResourceAttributesConfig
type ResourceBuilder ¶ added in v0.82.0
type ResourceBuilder struct {
// contains filtered or unexported fields
}
ResourceBuilder is a helper struct to build resources predefined in metadata.yaml. The ResourceBuilder is not thread-safe and must not to be used in multiple goroutines.
func NewResourceBuilder ¶ added in v0.82.0
func NewResourceBuilder(rac ResourceAttributesConfig) *ResourceBuilder
NewResourceBuilder creates a new ResourceBuilder. This method should be called on the start of the application.
func (*ResourceBuilder) Emit ¶ added in v0.82.0
func (rb *ResourceBuilder) Emit() pcommon.Resource
Emit returns the built resource and resets the internal builder state.
func (*ResourceBuilder) SetContainerID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetContainerID(val string)
SetContainerID sets provided value as "container.id" attribute.
func (*ResourceBuilder) SetContainerImageName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetContainerImageName(val string)
SetContainerImageName sets provided value as "container.image.name" attribute.
func (*ResourceBuilder) SetContainerImageTag ¶ added in v0.82.0
func (rb *ResourceBuilder) SetContainerImageTag(val string)
SetContainerImageTag sets provided value as "container.image.tag" attribute.
func (*ResourceBuilder) SetK8sContainerName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sContainerName(val string)
SetK8sContainerName sets provided value as "k8s.container.name" attribute.
func (*ResourceBuilder) SetK8sCronjobName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sCronjobName(val string)
SetK8sCronjobName sets provided value as "k8s.cronjob.name" attribute.
func (*ResourceBuilder) SetK8sCronjobUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sCronjobUID(val string)
SetK8sCronjobUID sets provided value as "k8s.cronjob.uid" attribute.
func (*ResourceBuilder) SetK8sDaemonsetName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sDaemonsetName(val string)
SetK8sDaemonsetName sets provided value as "k8s.daemonset.name" attribute.
func (*ResourceBuilder) SetK8sDaemonsetUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sDaemonsetUID(val string)
SetK8sDaemonsetUID sets provided value as "k8s.daemonset.uid" attribute.
func (*ResourceBuilder) SetK8sDeploymentName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sDeploymentName(val string)
SetK8sDeploymentName sets provided value as "k8s.deployment.name" attribute.
func (*ResourceBuilder) SetK8sDeploymentUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sDeploymentUID(val string)
SetK8sDeploymentUID sets provided value as "k8s.deployment.uid" attribute.
func (*ResourceBuilder) SetK8sHpaName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sHpaName(val string)
SetK8sHpaName sets provided value as "k8s.hpa.name" attribute.
func (*ResourceBuilder) SetK8sHpaUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sHpaUID(val string)
SetK8sHpaUID sets provided value as "k8s.hpa.uid" attribute.
func (*ResourceBuilder) SetK8sJobName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sJobName(val string)
SetK8sJobName sets provided value as "k8s.job.name" attribute.
func (*ResourceBuilder) SetK8sJobUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sJobUID(val string)
SetK8sJobUID sets provided value as "k8s.job.uid" attribute.
func (*ResourceBuilder) SetK8sKubeletVersion ¶ added in v0.85.0
func (rb *ResourceBuilder) SetK8sKubeletVersion(val string)
SetK8sKubeletVersion sets provided value as "k8s.kubelet.version" attribute.
func (*ResourceBuilder) SetK8sKubeproxyVersion ¶ added in v0.85.0
func (rb *ResourceBuilder) SetK8sKubeproxyVersion(val string)
SetK8sKubeproxyVersion sets provided value as "k8s.kubeproxy.version" attribute.
func (*ResourceBuilder) SetK8sNamespaceName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sNamespaceName(val string)
SetK8sNamespaceName sets provided value as "k8s.namespace.name" attribute.
func (*ResourceBuilder) SetK8sNamespaceUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sNamespaceUID(val string)
SetK8sNamespaceUID sets provided value as "k8s.namespace.uid" attribute.
func (*ResourceBuilder) SetK8sNodeName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sNodeName(val string)
SetK8sNodeName sets provided value as "k8s.node.name" attribute.
func (*ResourceBuilder) SetK8sNodeUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sNodeUID(val string)
SetK8sNodeUID sets provided value as "k8s.node.uid" attribute.
func (*ResourceBuilder) SetK8sPodName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sPodName(val string)
SetK8sPodName sets provided value as "k8s.pod.name" attribute.
func (*ResourceBuilder) SetK8sPodQosClass ¶ added in v0.88.0
func (rb *ResourceBuilder) SetK8sPodQosClass(val string)
SetK8sPodQosClass sets provided value as "k8s.pod.qos_class" attribute.
func (*ResourceBuilder) SetK8sPodUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sPodUID(val string)
SetK8sPodUID sets provided value as "k8s.pod.uid" attribute.
func (*ResourceBuilder) SetK8sReplicasetName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sReplicasetName(val string)
SetK8sReplicasetName sets provided value as "k8s.replicaset.name" attribute.
func (*ResourceBuilder) SetK8sReplicasetUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sReplicasetUID(val string)
SetK8sReplicasetUID sets provided value as "k8s.replicaset.uid" attribute.
func (*ResourceBuilder) SetK8sReplicationcontrollerName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sReplicationcontrollerName(val string)
SetK8sReplicationcontrollerName sets provided value as "k8s.replicationcontroller.name" attribute.
func (*ResourceBuilder) SetK8sReplicationcontrollerUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sReplicationcontrollerUID(val string)
SetK8sReplicationcontrollerUID sets provided value as "k8s.replicationcontroller.uid" attribute.
func (*ResourceBuilder) SetK8sResourcequotaName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sResourcequotaName(val string)
SetK8sResourcequotaName sets provided value as "k8s.resourcequota.name" attribute.
func (*ResourceBuilder) SetK8sResourcequotaUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sResourcequotaUID(val string)
SetK8sResourcequotaUID sets provided value as "k8s.resourcequota.uid" attribute.
func (*ResourceBuilder) SetK8sStatefulsetName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sStatefulsetName(val string)
SetK8sStatefulsetName sets provided value as "k8s.statefulset.name" attribute.
func (*ResourceBuilder) SetK8sStatefulsetUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetK8sStatefulsetUID(val string)
SetK8sStatefulsetUID sets provided value as "k8s.statefulset.uid" attribute.
func (*ResourceBuilder) SetOpenshiftClusterquotaName ¶ added in v0.82.0
func (rb *ResourceBuilder) SetOpenshiftClusterquotaName(val string)
SetOpenshiftClusterquotaName sets provided value as "openshift.clusterquota.name" attribute.
func (*ResourceBuilder) SetOpenshiftClusterquotaUID ¶ added in v0.82.0
func (rb *ResourceBuilder) SetOpenshiftClusterquotaUID(val string)
SetOpenshiftClusterquotaUID sets provided value as "openshift.clusterquota.uid" attribute.
type ResourceMetricsOption ¶ added in v0.82.0
type ResourceMetricsOption func(pmetric.ResourceMetrics)
ResourceMetricsOption applies changes to provided resource metrics.
func WithResource ¶ added in v0.82.0
func WithResource(res pcommon.Resource) ResourceMetricsOption
WithResource sets the provided resource on the emitted ResourceMetrics. It's recommended to use ResourceBuilder to create the resource.
func WithStartTimeOverride ¶ added in v0.82.0
func WithStartTimeOverride(start pcommon.Timestamp) ResourceMetricsOption
WithStartTimeOverride overrides start time for all the resource metrics data points. This option should be only used if different start time has to be set on metrics coming from different resources.
type Store ¶
type Store struct {
// contains filtered or unexported fields
}
Store keeps track of required caches exposed by informers. This store is used while collecting metadata about Pods to be able to correlate other Kubernetes objects with a Pod.
func (*Store) ForEach ¶ added in v0.83.0
func (ms *Store) ForEach(gvk schema.GroupVersionKind, f func(o any))
ForEach iterates over all objects in a given cache.Store.