diff --git a/internal/tools/go.mod b/internal/tools/go.mod index a5a9a42cd5be..deb391b73774 100644 --- a/internal/tools/go.mod +++ b/internal/tools/go.mod @@ -16,7 +16,7 @@ require ( go.opentelemetry.io/build-tools/issuegenerator v0.13.0 go.opentelemetry.io/build-tools/multimod v0.13.0 go.opentelemetry.io/collector/cmd/builder v0.98.1-0.20240419202408-d1e631b61158 - go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240419202408-d1e631b61158 + go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240422153235-cc9e3dd3ec26 go.uber.org/goleak v1.3.0 golang.org/x/tools v0.20.0 golang.org/x/vuln v1.1.0 diff --git a/internal/tools/go.sum b/internal/tools/go.sum index 4857758a33b4..98629484b820 100644 --- a/internal/tools/go.sum +++ b/internal/tools/go.sum @@ -705,8 +705,8 @@ go.opentelemetry.io/build-tools/multimod v0.13.0 h1:HGAP3zCM8vOTNJSQbjQ5VbKZSctI go.opentelemetry.io/build-tools/multimod v0.13.0/go.mod h1:CxZp68c4PIN+bYlVOGB2FvE5zZMBuGz7cGSHv2L7pSc= go.opentelemetry.io/collector/cmd/builder v0.98.1-0.20240419202408-d1e631b61158 h1:yakPcu/ShcT4iMLDJMgRd54OEi3Pz8g63CS4w9RZKj8= go.opentelemetry.io/collector/cmd/builder v0.98.1-0.20240419202408-d1e631b61158/go.mod h1:4t5OOXstaQw3xXIVpUFMxbIiB5+gtr1nZSgQ1KMH/AE= -go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240419202408-d1e631b61158 h1:BbzCJw4Kbp1aJlmjyrmFnisPKqNsbzbYV+8XIJLOORs= -go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240419202408-d1e631b61158/go.mod h1:u1vcHMP2EQHBySTBDlvxwfvxg3joH/bKS1g0wZgTZh0= +go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240422153235-cc9e3dd3ec26 h1:QLUeQl/y6JflJxLaqOJS43QJSK6aC1lR9VcWUe2D6nY= +go.opentelemetry.io/collector/cmd/mdatagen v0.98.1-0.20240422153235-cc9e3dd3ec26/go.mod h1:u1vcHMP2EQHBySTBDlvxwfvxg3joH/bKS1g0wZgTZh0= go.opentelemetry.io/collector/component v0.98.1-0.20240419202408-d1e631b61158 h1:0YfMQn1FmTZLvR8i/GiTMySmL+TbRgLw8RJJn+Ngn0s= go.opentelemetry.io/collector/component v0.98.1-0.20240419202408-d1e631b61158/go.mod h1:Izg+KusBT3lft3t7mvaM5aw7DVusFu/Wxu3edIP7WIA= go.opentelemetry.io/collector/config/configtelemetry v0.98.1-0.20240419202408-d1e631b61158 h1:+GOz5fVzZdcbqcTEXIMJnRT38Yx+uED6n+UJ5RRUr64= diff --git a/receiver/aerospikereceiver/internal/metadata/generated_config.go b/receiver/aerospikereceiver/internal/metadata/generated_config.go index 442d0ed372f0..b6d5107d5c5d 100644 --- a/receiver/aerospikereceiver/internal/metadata/generated_config.go +++ b/receiver/aerospikereceiver/internal/metadata/generated_config.go @@ -93,9 +93,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/aerospikereceiver/internal/metadata/generated_metrics.go b/receiver/aerospikereceiver/internal/metadata/generated_metrics.go index 31939cc1ba58..d07babd696ab 100644 --- a/receiver/aerospikereceiver/internal/metadata/generated_metrics.go +++ b/receiver/aerospikereceiver/internal/metadata/generated_metrics.go @@ -1130,17 +1130,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.AerospikeNamespace.Include != nil { - mb.resourceAttributeIncludeFilter["aerospike.namespace"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNamespace.Include) + if mbc.ResourceAttributes.AerospikeNamespace.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["aerospike.namespace"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNamespace.MetricsInclude) } - if mbc.ResourceAttributes.AerospikeNamespace.Exclude != nil { - mb.resourceAttributeExcludeFilter["aerospike.namespace"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNamespace.Exclude) + if mbc.ResourceAttributes.AerospikeNamespace.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["aerospike.namespace"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNamespace.MetricsExclude) } - if mbc.ResourceAttributes.AerospikeNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["aerospike.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNodeName.Include) + if mbc.ResourceAttributes.AerospikeNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["aerospike.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNodeName.MetricsInclude) } - if mbc.ResourceAttributes.AerospikeNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["aerospike.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNodeName.Exclude) + if mbc.ResourceAttributes.AerospikeNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["aerospike.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.AerospikeNodeName.MetricsExclude) } for _, op := range options { diff --git a/receiver/aerospikereceiver/internal/metadata/testdata/config.yaml b/receiver/aerospikereceiver/internal/metadata/testdata/config.yaml index 9192ace4cec0..5fd54f293d1f 100644 --- a/receiver/aerospikereceiver/internal/metadata/testdata/config.yaml +++ b/receiver/aerospikereceiver/internal/metadata/testdata/config.yaml @@ -73,19 +73,19 @@ filter_set_include: resource_attributes: aerospike.namespace: enabled: true - include: + metrics_include: - regexp: ".*" aerospike.node.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: aerospike.namespace: enabled: true - exclude: + metrics_exclude: - strict: "aerospike.namespace-val" aerospike.node.name: enabled: true - exclude: + metrics_exclude: - strict: "aerospike.node.name-val" diff --git a/receiver/apachereceiver/internal/metadata/generated_config.go b/receiver/apachereceiver/internal/metadata/generated_config.go index 8a8f50252f4b..bfa38e39f194 100644 --- a/receiver/apachereceiver/internal/metadata/generated_config.go +++ b/receiver/apachereceiver/internal/metadata/generated_config.go @@ -85,9 +85,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/apachereceiver/internal/metadata/generated_metrics.go b/receiver/apachereceiver/internal/metadata/generated_metrics.go index a7251601b0ae..48edcca11420 100644 --- a/receiver/apachereceiver/internal/metadata/generated_metrics.go +++ b/receiver/apachereceiver/internal/metadata/generated_metrics.go @@ -824,17 +824,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ApacheServerName.Include != nil { - mb.resourceAttributeIncludeFilter["apache.server.name"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerName.Include) + if mbc.ResourceAttributes.ApacheServerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["apache.server.name"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerName.MetricsInclude) } - if mbc.ResourceAttributes.ApacheServerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["apache.server.name"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerName.Exclude) + if mbc.ResourceAttributes.ApacheServerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["apache.server.name"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerName.MetricsExclude) } - if mbc.ResourceAttributes.ApacheServerPort.Include != nil { - mb.resourceAttributeIncludeFilter["apache.server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerPort.Include) + if mbc.ResourceAttributes.ApacheServerPort.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["apache.server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerPort.MetricsInclude) } - if mbc.ResourceAttributes.ApacheServerPort.Exclude != nil { - mb.resourceAttributeExcludeFilter["apache.server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerPort.Exclude) + if mbc.ResourceAttributes.ApacheServerPort.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["apache.server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ApacheServerPort.MetricsExclude) } for _, op := range options { diff --git a/receiver/apachereceiver/internal/metadata/testdata/config.yaml b/receiver/apachereceiver/internal/metadata/testdata/config.yaml index 66abef50cfa7..695dc7ed0cec 100644 --- a/receiver/apachereceiver/internal/metadata/testdata/config.yaml +++ b/receiver/apachereceiver/internal/metadata/testdata/config.yaml @@ -65,19 +65,19 @@ filter_set_include: resource_attributes: apache.server.name: enabled: true - include: + metrics_include: - regexp: ".*" apache.server.port: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: apache.server.name: enabled: true - exclude: + metrics_exclude: - strict: "apache.server.name-val" apache.server.port: enabled: true - exclude: + metrics_exclude: - strict: "apache.server.port-val" diff --git a/receiver/apachesparkreceiver/internal/metadata/generated_config.go b/receiver/apachesparkreceiver/internal/metadata/generated_config.go index ed531ffe3c8f..1f95d5e7a5b0 100644 --- a/receiver/apachesparkreceiver/internal/metadata/generated_config.go +++ b/receiver/apachesparkreceiver/internal/metadata/generated_config.go @@ -289,9 +289,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/apachesparkreceiver/internal/metadata/generated_metrics.go b/receiver/apachesparkreceiver/internal/metadata/generated_metrics.go index fb7c13ef310e..6749ee1b4f3a 100644 --- a/receiver/apachesparkreceiver/internal/metadata/generated_metrics.go +++ b/receiver/apachesparkreceiver/internal/metadata/generated_metrics.go @@ -3685,41 +3685,41 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.SparkApplicationID.Include != nil { - mb.resourceAttributeIncludeFilter["spark.application.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationID.Include) + if mbc.ResourceAttributes.SparkApplicationID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.application.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationID.MetricsInclude) } - if mbc.ResourceAttributes.SparkApplicationID.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.application.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationID.Exclude) + if mbc.ResourceAttributes.SparkApplicationID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.application.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationID.MetricsExclude) } - if mbc.ResourceAttributes.SparkApplicationName.Include != nil { - mb.resourceAttributeIncludeFilter["spark.application.name"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationName.Include) + if mbc.ResourceAttributes.SparkApplicationName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.application.name"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationName.MetricsInclude) } - if mbc.ResourceAttributes.SparkApplicationName.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.application.name"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationName.Exclude) + if mbc.ResourceAttributes.SparkApplicationName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.application.name"] = filter.CreateFilter(mbc.ResourceAttributes.SparkApplicationName.MetricsExclude) } - if mbc.ResourceAttributes.SparkExecutorID.Include != nil { - mb.resourceAttributeIncludeFilter["spark.executor.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkExecutorID.Include) + if mbc.ResourceAttributes.SparkExecutorID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.executor.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkExecutorID.MetricsInclude) } - if mbc.ResourceAttributes.SparkExecutorID.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.executor.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkExecutorID.Exclude) + if mbc.ResourceAttributes.SparkExecutorID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.executor.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkExecutorID.MetricsExclude) } - if mbc.ResourceAttributes.SparkJobID.Include != nil { - mb.resourceAttributeIncludeFilter["spark.job.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkJobID.Include) + if mbc.ResourceAttributes.SparkJobID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.job.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkJobID.MetricsInclude) } - if mbc.ResourceAttributes.SparkJobID.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.job.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkJobID.Exclude) + if mbc.ResourceAttributes.SparkJobID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.job.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkJobID.MetricsExclude) } - if mbc.ResourceAttributes.SparkStageAttemptID.Include != nil { - mb.resourceAttributeIncludeFilter["spark.stage.attempt.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageAttemptID.Include) + if mbc.ResourceAttributes.SparkStageAttemptID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.stage.attempt.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageAttemptID.MetricsInclude) } - if mbc.ResourceAttributes.SparkStageAttemptID.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.stage.attempt.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageAttemptID.Exclude) + if mbc.ResourceAttributes.SparkStageAttemptID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.stage.attempt.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageAttemptID.MetricsExclude) } - if mbc.ResourceAttributes.SparkStageID.Include != nil { - mb.resourceAttributeIncludeFilter["spark.stage.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageID.Include) + if mbc.ResourceAttributes.SparkStageID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["spark.stage.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageID.MetricsInclude) } - if mbc.ResourceAttributes.SparkStageID.Exclude != nil { - mb.resourceAttributeExcludeFilter["spark.stage.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageID.Exclude) + if mbc.ResourceAttributes.SparkStageID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["spark.stage.id"] = filter.CreateFilter(mbc.ResourceAttributes.SparkStageID.MetricsExclude) } for _, op := range options { diff --git a/receiver/apachesparkreceiver/internal/metadata/testdata/config.yaml b/receiver/apachesparkreceiver/internal/metadata/testdata/config.yaml index 8db1fcc17c5c..9543866f8eeb 100644 --- a/receiver/apachesparkreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/apachesparkreceiver/internal/metadata/testdata/config.yaml @@ -285,51 +285,51 @@ filter_set_include: resource_attributes: spark.application.id: enabled: true - include: + metrics_include: - regexp: ".*" spark.application.name: enabled: true - include: + metrics_include: - regexp: ".*" spark.executor.id: enabled: true - include: + metrics_include: - regexp: ".*" spark.job.id: enabled: true - include: + metrics_include: - regexp: ".*" spark.stage.attempt.id: enabled: true - include: + metrics_include: - regexp: ".*" spark.stage.id: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: spark.application.id: enabled: true - exclude: + metrics_exclude: - strict: "spark.application.id-val" spark.application.name: enabled: true - exclude: + metrics_exclude: - strict: "spark.application.name-val" spark.executor.id: enabled: true - exclude: + metrics_exclude: - strict: "spark.executor.id-val" spark.job.id: enabled: true - exclude: + metrics_exclude: - regexp: ".*" spark.stage.attempt.id: enabled: true - exclude: + metrics_exclude: - regexp: ".*" spark.stage.id: enabled: true - exclude: + metrics_exclude: - regexp: ".*" diff --git a/receiver/bigipreceiver/internal/metadata/generated_config.go b/receiver/bigipreceiver/internal/metadata/generated_config.go index 2c6142fd7b3c..b070d76a5d2d 100644 --- a/receiver/bigipreceiver/internal/metadata/generated_config.go +++ b/receiver/bigipreceiver/internal/metadata/generated_config.go @@ -145,9 +145,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/bigipreceiver/internal/metadata/generated_metrics.go b/receiver/bigipreceiver/internal/metadata/generated_metrics.go index 57067081cc95..1dcd542b8961 100644 --- a/receiver/bigipreceiver/internal/metadata/generated_metrics.go +++ b/receiver/bigipreceiver/internal/metadata/generated_metrics.go @@ -1600,47 +1600,47 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.BigipNodeIPAddress.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.node.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeIPAddress.Include) + if mbc.ResourceAttributes.BigipNodeIPAddress.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.node.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeIPAddress.MetricsInclude) } - if mbc.ResourceAttributes.BigipNodeIPAddress.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.node.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeIPAddress.Exclude) + if mbc.ResourceAttributes.BigipNodeIPAddress.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.node.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeIPAddress.MetricsExclude) } - if mbc.ResourceAttributes.BigipNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeName.Include) + if mbc.ResourceAttributes.BigipNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeName.MetricsInclude) } - if mbc.ResourceAttributes.BigipNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeName.Exclude) + if mbc.ResourceAttributes.BigipNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipNodeName.MetricsExclude) } - if mbc.ResourceAttributes.BigipPoolName.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolName.Include) + if mbc.ResourceAttributes.BigipPoolName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolName.MetricsInclude) } - if mbc.ResourceAttributes.BigipPoolName.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolName.Exclude) + if mbc.ResourceAttributes.BigipPoolName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolName.MetricsExclude) } - if mbc.ResourceAttributes.BigipPoolMemberIPAddress.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.pool_member.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberIPAddress.Include) + if mbc.ResourceAttributes.BigipPoolMemberIPAddress.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.pool_member.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberIPAddress.MetricsInclude) } - if mbc.ResourceAttributes.BigipPoolMemberIPAddress.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.pool_member.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberIPAddress.Exclude) + if mbc.ResourceAttributes.BigipPoolMemberIPAddress.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.pool_member.ip_address"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberIPAddress.MetricsExclude) } - if mbc.ResourceAttributes.BigipPoolMemberName.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.pool_member.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberName.Include) + if mbc.ResourceAttributes.BigipPoolMemberName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.pool_member.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberName.MetricsInclude) } - if mbc.ResourceAttributes.BigipPoolMemberName.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.pool_member.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberName.Exclude) + if mbc.ResourceAttributes.BigipPoolMemberName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.pool_member.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipPoolMemberName.MetricsExclude) } - if mbc.ResourceAttributes.BigipVirtualServerDestination.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.virtual_server.destination"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerDestination.Include) + if mbc.ResourceAttributes.BigipVirtualServerDestination.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.virtual_server.destination"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerDestination.MetricsInclude) } - if mbc.ResourceAttributes.BigipVirtualServerDestination.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.virtual_server.destination"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerDestination.Exclude) + if mbc.ResourceAttributes.BigipVirtualServerDestination.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.virtual_server.destination"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerDestination.MetricsExclude) } - if mbc.ResourceAttributes.BigipVirtualServerName.Include != nil { - mb.resourceAttributeIncludeFilter["bigip.virtual_server.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerName.Include) + if mbc.ResourceAttributes.BigipVirtualServerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["bigip.virtual_server.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerName.MetricsInclude) } - if mbc.ResourceAttributes.BigipVirtualServerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["bigip.virtual_server.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerName.Exclude) + if mbc.ResourceAttributes.BigipVirtualServerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["bigip.virtual_server.name"] = filter.CreateFilter(mbc.ResourceAttributes.BigipVirtualServerName.MetricsExclude) } for _, op := range options { diff --git a/receiver/bigipreceiver/internal/metadata/testdata/config.yaml b/receiver/bigipreceiver/internal/metadata/testdata/config.yaml index 7a26614d1335..adb7fc9a03a8 100644 --- a/receiver/bigipreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/bigipreceiver/internal/metadata/testdata/config.yaml @@ -145,59 +145,59 @@ filter_set_include: resource_attributes: bigip.node.ip_address: enabled: true - include: + metrics_include: - regexp: ".*" bigip.node.name: enabled: true - include: + metrics_include: - regexp: ".*" bigip.pool.name: enabled: true - include: + metrics_include: - regexp: ".*" bigip.pool_member.ip_address: enabled: true - include: + metrics_include: - regexp: ".*" bigip.pool_member.name: enabled: true - include: + metrics_include: - regexp: ".*" bigip.virtual_server.destination: enabled: true - include: + metrics_include: - regexp: ".*" bigip.virtual_server.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: bigip.node.ip_address: enabled: true - exclude: + metrics_exclude: - strict: "bigip.node.ip_address-val" bigip.node.name: enabled: true - exclude: + metrics_exclude: - strict: "bigip.node.name-val" bigip.pool.name: enabled: true - exclude: + metrics_exclude: - strict: "bigip.pool.name-val" bigip.pool_member.ip_address: enabled: true - exclude: + metrics_exclude: - strict: "bigip.pool_member.ip_address-val" bigip.pool_member.name: enabled: true - exclude: + metrics_exclude: - strict: "bigip.pool_member.name-val" bigip.virtual_server.destination: enabled: true - exclude: + metrics_exclude: - strict: "bigip.virtual_server.destination-val" bigip.virtual_server.name: enabled: true - exclude: + metrics_exclude: - strict: "bigip.virtual_server.name-val" diff --git a/receiver/couchdbreceiver/internal/metadata/generated_config.go b/receiver/couchdbreceiver/internal/metadata/generated_config.go index 5abebdbcb798..0152fff47fc2 100644 --- a/receiver/couchdbreceiver/internal/metadata/generated_config.go +++ b/receiver/couchdbreceiver/internal/metadata/generated_config.go @@ -69,9 +69,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/couchdbreceiver/internal/metadata/generated_metrics.go b/receiver/couchdbreceiver/internal/metadata/generated_metrics.go index f9c33d6f6aa6..8d894dc21640 100644 --- a/receiver/couchdbreceiver/internal/metadata/generated_metrics.go +++ b/receiver/couchdbreceiver/internal/metadata/generated_metrics.go @@ -571,11 +571,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.CouchdbNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["couchdb.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.CouchdbNodeName.Include) + if mbc.ResourceAttributes.CouchdbNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["couchdb.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.CouchdbNodeName.MetricsInclude) } - if mbc.ResourceAttributes.CouchdbNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["couchdb.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.CouchdbNodeName.Exclude) + if mbc.ResourceAttributes.CouchdbNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["couchdb.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.CouchdbNodeName.MetricsExclude) } for _, op := range options { diff --git a/receiver/couchdbreceiver/internal/metadata/testdata/config.yaml b/receiver/couchdbreceiver/internal/metadata/testdata/config.yaml index 00ea24f7e59d..e28c8c0c6d78 100644 --- a/receiver/couchdbreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/couchdbreceiver/internal/metadata/testdata/config.yaml @@ -45,11 +45,11 @@ filter_set_include: resource_attributes: couchdb.node.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: couchdb.node.name: enabled: true - exclude: + metrics_exclude: - strict: "couchdb.node.name-val" diff --git a/receiver/dockerstatsreceiver/internal/metadata/generated_config.go b/receiver/dockerstatsreceiver/internal/metadata/generated_config.go index 12924b3bc1e6..00d5e99a5ee6 100644 --- a/receiver/dockerstatsreceiver/internal/metadata/generated_config.go +++ b/receiver/dockerstatsreceiver/internal/metadata/generated_config.go @@ -321,9 +321,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/dockerstatsreceiver/internal/metadata/generated_metrics.go b/receiver/dockerstatsreceiver/internal/metadata/generated_metrics.go index 59a3829ad4a4..376102e9b0d0 100644 --- a/receiver/dockerstatsreceiver/internal/metadata/generated_metrics.go +++ b/receiver/dockerstatsreceiver/internal/metadata/generated_metrics.go @@ -3845,47 +3845,47 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ContainerCommandLine.Include != nil { - mb.resourceAttributeIncludeFilter["container.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerCommandLine.Include) + if mbc.ResourceAttributes.ContainerCommandLine.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerCommandLine.MetricsInclude) } - if mbc.ResourceAttributes.ContainerCommandLine.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerCommandLine.Exclude) + if mbc.ResourceAttributes.ContainerCommandLine.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerCommandLine.MetricsExclude) } - if mbc.ResourceAttributes.ContainerHostname.Include != nil { - mb.resourceAttributeIncludeFilter["container.hostname"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerHostname.Include) + if mbc.ResourceAttributes.ContainerHostname.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.hostname"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerHostname.MetricsInclude) } - if mbc.ResourceAttributes.ContainerHostname.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.hostname"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerHostname.Exclude) + if mbc.ResourceAttributes.ContainerHostname.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.hostname"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerHostname.MetricsExclude) } - if mbc.ResourceAttributes.ContainerID.Include != nil { - mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Include) + if mbc.ResourceAttributes.ContainerID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsInclude) } - if mbc.ResourceAttributes.ContainerID.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Exclude) + if mbc.ResourceAttributes.ContainerID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsExclude) } - if mbc.ResourceAttributes.ContainerImageID.Include != nil { - mb.resourceAttributeIncludeFilter["container.image.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageID.Include) + if mbc.ResourceAttributes.ContainerImageID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.image.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageID.MetricsInclude) } - if mbc.ResourceAttributes.ContainerImageID.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.image.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageID.Exclude) + if mbc.ResourceAttributes.ContainerImageID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.image.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageID.MetricsExclude) } - if mbc.ResourceAttributes.ContainerImageName.Include != nil { - mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Include) + if mbc.ResourceAttributes.ContainerImageName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsInclude) } - if mbc.ResourceAttributes.ContainerImageName.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Exclude) + if mbc.ResourceAttributes.ContainerImageName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsExclude) } - if mbc.ResourceAttributes.ContainerName.Include != nil { - mb.resourceAttributeIncludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.Include) + if mbc.ResourceAttributes.ContainerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.MetricsInclude) } - if mbc.ResourceAttributes.ContainerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.Exclude) + if mbc.ResourceAttributes.ContainerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.MetricsExclude) } - if mbc.ResourceAttributes.ContainerRuntime.Include != nil { - mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Include) + if mbc.ResourceAttributes.ContainerRuntime.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsInclude) } - if mbc.ResourceAttributes.ContainerRuntime.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Exclude) + if mbc.ResourceAttributes.ContainerRuntime.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsExclude) } for _, op := range options { diff --git a/receiver/dockerstatsreceiver/internal/metadata/testdata/config.yaml b/receiver/dockerstatsreceiver/internal/metadata/testdata/config.yaml index 1a1c5b0a63c5..34f3f7419590 100644 --- a/receiver/dockerstatsreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/dockerstatsreceiver/internal/metadata/testdata/config.yaml @@ -321,59 +321,59 @@ filter_set_include: resource_attributes: container.command_line: enabled: true - include: + metrics_include: - regexp: ".*" container.hostname: enabled: true - include: + metrics_include: - regexp: ".*" container.id: enabled: true - include: + metrics_include: - regexp: ".*" container.image.id: enabled: true - include: + metrics_include: - regexp: ".*" container.image.name: enabled: true - include: + metrics_include: - regexp: ".*" container.name: enabled: true - include: + metrics_include: - regexp: ".*" container.runtime: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: container.command_line: enabled: true - exclude: + metrics_exclude: - strict: "container.command_line-val" container.hostname: enabled: true - exclude: + metrics_exclude: - strict: "container.hostname-val" container.id: enabled: true - exclude: + metrics_exclude: - strict: "container.id-val" container.image.id: enabled: true - exclude: + metrics_exclude: - strict: "container.image.id-val" container.image.name: enabled: true - exclude: + metrics_exclude: - strict: "container.image.name-val" container.name: enabled: true - exclude: + metrics_exclude: - strict: "container.name-val" container.runtime: enabled: true - exclude: + metrics_exclude: - strict: "container.runtime-val" diff --git a/receiver/elasticsearchreceiver/internal/metadata/generated_config.go b/receiver/elasticsearchreceiver/internal/metadata/generated_config.go index 161a2328b717..c1f3b8b170d6 100644 --- a/receiver/elasticsearchreceiver/internal/metadata/generated_config.go +++ b/receiver/elasticsearchreceiver/internal/metadata/generated_config.go @@ -401,9 +401,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/elasticsearchreceiver/internal/metadata/generated_metrics.go b/receiver/elasticsearchreceiver/internal/metadata/generated_metrics.go index ec39d4ca0eaf..f2f774aab852 100644 --- a/receiver/elasticsearchreceiver/internal/metadata/generated_metrics.go +++ b/receiver/elasticsearchreceiver/internal/metadata/generated_metrics.go @@ -5457,29 +5457,29 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ElasticsearchClusterName.Include != nil { - mb.resourceAttributeIncludeFilter["elasticsearch.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchClusterName.Include) + if mbc.ResourceAttributes.ElasticsearchClusterName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["elasticsearch.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchClusterName.MetricsInclude) } - if mbc.ResourceAttributes.ElasticsearchClusterName.Exclude != nil { - mb.resourceAttributeExcludeFilter["elasticsearch.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchClusterName.Exclude) + if mbc.ResourceAttributes.ElasticsearchClusterName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["elasticsearch.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchClusterName.MetricsExclude) } - if mbc.ResourceAttributes.ElasticsearchIndexName.Include != nil { - mb.resourceAttributeIncludeFilter["elasticsearch.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchIndexName.Include) + if mbc.ResourceAttributes.ElasticsearchIndexName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["elasticsearch.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchIndexName.MetricsInclude) } - if mbc.ResourceAttributes.ElasticsearchIndexName.Exclude != nil { - mb.resourceAttributeExcludeFilter["elasticsearch.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchIndexName.Exclude) + if mbc.ResourceAttributes.ElasticsearchIndexName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["elasticsearch.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchIndexName.MetricsExclude) } - if mbc.ResourceAttributes.ElasticsearchNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["elasticsearch.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeName.Include) + if mbc.ResourceAttributes.ElasticsearchNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["elasticsearch.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeName.MetricsInclude) } - if mbc.ResourceAttributes.ElasticsearchNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["elasticsearch.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeName.Exclude) + if mbc.ResourceAttributes.ElasticsearchNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["elasticsearch.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeName.MetricsExclude) } - if mbc.ResourceAttributes.ElasticsearchNodeVersion.Include != nil { - mb.resourceAttributeIncludeFilter["elasticsearch.node.version"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeVersion.Include) + if mbc.ResourceAttributes.ElasticsearchNodeVersion.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["elasticsearch.node.version"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeVersion.MetricsInclude) } - if mbc.ResourceAttributes.ElasticsearchNodeVersion.Exclude != nil { - mb.resourceAttributeExcludeFilter["elasticsearch.node.version"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeVersion.Exclude) + if mbc.ResourceAttributes.ElasticsearchNodeVersion.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["elasticsearch.node.version"] = filter.CreateFilter(mbc.ResourceAttributes.ElasticsearchNodeVersion.MetricsExclude) } for _, op := range options { diff --git a/receiver/elasticsearchreceiver/internal/metadata/testdata/config.yaml b/receiver/elasticsearchreceiver/internal/metadata/testdata/config.yaml index f5b7d0471e0b..ebb918407bab 100644 --- a/receiver/elasticsearchreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/elasticsearchreceiver/internal/metadata/testdata/config.yaml @@ -389,35 +389,35 @@ filter_set_include: resource_attributes: elasticsearch.cluster.name: enabled: true - include: + metrics_include: - regexp: ".*" elasticsearch.index.name: enabled: true - include: + metrics_include: - regexp: ".*" elasticsearch.node.name: enabled: true - include: + metrics_include: - regexp: ".*" elasticsearch.node.version: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: elasticsearch.cluster.name: enabled: true - exclude: + metrics_exclude: - strict: "elasticsearch.cluster.name-val" elasticsearch.index.name: enabled: true - exclude: + metrics_exclude: - strict: "elasticsearch.index.name-val" elasticsearch.node.name: enabled: true - exclude: + metrics_exclude: - strict: "elasticsearch.node.name-val" elasticsearch.node.version: enabled: true - exclude: + metrics_exclude: - strict: "elasticsearch.node.version-val" diff --git a/receiver/filestatsreceiver/internal/metadata/generated_config.go b/receiver/filestatsreceiver/internal/metadata/generated_config.go index 63ae13a1d666..4b681d4b7c64 100644 --- a/receiver/filestatsreceiver/internal/metadata/generated_config.go +++ b/receiver/filestatsreceiver/internal/metadata/generated_config.go @@ -57,9 +57,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/filestatsreceiver/internal/metadata/generated_metrics.go b/receiver/filestatsreceiver/internal/metadata/generated_metrics.go index e87675883de7..2ffe5e2e8b8e 100644 --- a/receiver/filestatsreceiver/internal/metadata/generated_metrics.go +++ b/receiver/filestatsreceiver/internal/metadata/generated_metrics.go @@ -306,17 +306,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.FileName.Include != nil { - mb.resourceAttributeIncludeFilter["file.name"] = filter.CreateFilter(mbc.ResourceAttributes.FileName.Include) + if mbc.ResourceAttributes.FileName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["file.name"] = filter.CreateFilter(mbc.ResourceAttributes.FileName.MetricsInclude) } - if mbc.ResourceAttributes.FileName.Exclude != nil { - mb.resourceAttributeExcludeFilter["file.name"] = filter.CreateFilter(mbc.ResourceAttributes.FileName.Exclude) + if mbc.ResourceAttributes.FileName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["file.name"] = filter.CreateFilter(mbc.ResourceAttributes.FileName.MetricsExclude) } - if mbc.ResourceAttributes.FilePath.Include != nil { - mb.resourceAttributeIncludeFilter["file.path"] = filter.CreateFilter(mbc.ResourceAttributes.FilePath.Include) + if mbc.ResourceAttributes.FilePath.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["file.path"] = filter.CreateFilter(mbc.ResourceAttributes.FilePath.MetricsInclude) } - if mbc.ResourceAttributes.FilePath.Exclude != nil { - mb.resourceAttributeExcludeFilter["file.path"] = filter.CreateFilter(mbc.ResourceAttributes.FilePath.Exclude) + if mbc.ResourceAttributes.FilePath.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["file.path"] = filter.CreateFilter(mbc.ResourceAttributes.FilePath.MetricsExclude) } for _, op := range options { diff --git a/receiver/filestatsreceiver/internal/metadata/testdata/config.yaml b/receiver/filestatsreceiver/internal/metadata/testdata/config.yaml index f133df98bd2a..3ddb1974fa7b 100644 --- a/receiver/filestatsreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/filestatsreceiver/internal/metadata/testdata/config.yaml @@ -37,19 +37,19 @@ filter_set_include: resource_attributes: file.name: enabled: true - include: + metrics_include: - regexp: ".*" file.path: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: file.name: enabled: true - exclude: + metrics_exclude: - strict: "file.name-val" file.path: enabled: true - exclude: + metrics_exclude: - strict: "file.path-val" diff --git a/receiver/flinkmetricsreceiver/internal/metadata/generated_config.go b/receiver/flinkmetricsreceiver/internal/metadata/generated_config.go index bfaaaf817f0c..7b12f89eb2b7 100644 --- a/receiver/flinkmetricsreceiver/internal/metadata/generated_config.go +++ b/receiver/flinkmetricsreceiver/internal/metadata/generated_config.go @@ -153,9 +153,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/flinkmetricsreceiver/internal/metadata/generated_metrics.go b/receiver/flinkmetricsreceiver/internal/metadata/generated_metrics.go index 1eb4032635ff..c3a1f6c6c45c 100644 --- a/receiver/flinkmetricsreceiver/internal/metadata/generated_metrics.go +++ b/receiver/flinkmetricsreceiver/internal/metadata/generated_metrics.go @@ -1681,41 +1681,41 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.FlinkJobName.Include != nil { - mb.resourceAttributeIncludeFilter["flink.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkJobName.Include) + if mbc.ResourceAttributes.FlinkJobName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["flink.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkJobName.MetricsInclude) } - if mbc.ResourceAttributes.FlinkJobName.Exclude != nil { - mb.resourceAttributeExcludeFilter["flink.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkJobName.Exclude) + if mbc.ResourceAttributes.FlinkJobName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["flink.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkJobName.MetricsExclude) } - if mbc.ResourceAttributes.FlinkResourceType.Include != nil { - mb.resourceAttributeIncludeFilter["flink.resource.type"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkResourceType.Include) + if mbc.ResourceAttributes.FlinkResourceType.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["flink.resource.type"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkResourceType.MetricsInclude) } - if mbc.ResourceAttributes.FlinkResourceType.Exclude != nil { - mb.resourceAttributeExcludeFilter["flink.resource.type"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkResourceType.Exclude) + if mbc.ResourceAttributes.FlinkResourceType.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["flink.resource.type"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkResourceType.MetricsExclude) } - if mbc.ResourceAttributes.FlinkSubtaskIndex.Include != nil { - mb.resourceAttributeIncludeFilter["flink.subtask.index"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkSubtaskIndex.Include) + if mbc.ResourceAttributes.FlinkSubtaskIndex.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["flink.subtask.index"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkSubtaskIndex.MetricsInclude) } - if mbc.ResourceAttributes.FlinkSubtaskIndex.Exclude != nil { - mb.resourceAttributeExcludeFilter["flink.subtask.index"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkSubtaskIndex.Exclude) + if mbc.ResourceAttributes.FlinkSubtaskIndex.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["flink.subtask.index"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkSubtaskIndex.MetricsExclude) } - if mbc.ResourceAttributes.FlinkTaskName.Include != nil { - mb.resourceAttributeIncludeFilter["flink.task.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskName.Include) + if mbc.ResourceAttributes.FlinkTaskName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["flink.task.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskName.MetricsInclude) } - if mbc.ResourceAttributes.FlinkTaskName.Exclude != nil { - mb.resourceAttributeExcludeFilter["flink.task.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskName.Exclude) + if mbc.ResourceAttributes.FlinkTaskName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["flink.task.name"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskName.MetricsExclude) } - if mbc.ResourceAttributes.FlinkTaskmanagerID.Include != nil { - mb.resourceAttributeIncludeFilter["flink.taskmanager.id"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskmanagerID.Include) + if mbc.ResourceAttributes.FlinkTaskmanagerID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["flink.taskmanager.id"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskmanagerID.MetricsInclude) } - if mbc.ResourceAttributes.FlinkTaskmanagerID.Exclude != nil { - mb.resourceAttributeExcludeFilter["flink.taskmanager.id"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskmanagerID.Exclude) + if mbc.ResourceAttributes.FlinkTaskmanagerID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["flink.taskmanager.id"] = filter.CreateFilter(mbc.ResourceAttributes.FlinkTaskmanagerID.MetricsExclude) } - if mbc.ResourceAttributes.HostName.Include != nil { - mb.resourceAttributeIncludeFilter["host.name"] = filter.CreateFilter(mbc.ResourceAttributes.HostName.Include) + if mbc.ResourceAttributes.HostName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["host.name"] = filter.CreateFilter(mbc.ResourceAttributes.HostName.MetricsInclude) } - if mbc.ResourceAttributes.HostName.Exclude != nil { - mb.resourceAttributeExcludeFilter["host.name"] = filter.CreateFilter(mbc.ResourceAttributes.HostName.Exclude) + if mbc.ResourceAttributes.HostName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["host.name"] = filter.CreateFilter(mbc.ResourceAttributes.HostName.MetricsExclude) } for _, op := range options { diff --git a/receiver/flinkmetricsreceiver/internal/metadata/testdata/config.yaml b/receiver/flinkmetricsreceiver/internal/metadata/testdata/config.yaml index c21b03c5fd65..af42eee485ca 100644 --- a/receiver/flinkmetricsreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/flinkmetricsreceiver/internal/metadata/testdata/config.yaml @@ -149,51 +149,51 @@ filter_set_include: resource_attributes: flink.job.name: enabled: true - include: + metrics_include: - regexp: ".*" flink.resource.type: enabled: true - include: + metrics_include: - regexp: ".*" flink.subtask.index: enabled: true - include: + metrics_include: - regexp: ".*" flink.task.name: enabled: true - include: + metrics_include: - regexp: ".*" flink.taskmanager.id: enabled: true - include: + metrics_include: - regexp: ".*" host.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: flink.job.name: enabled: true - exclude: + metrics_exclude: - strict: "flink.job.name-val" flink.resource.type: enabled: true - exclude: + metrics_exclude: - strict: "jobmanager" flink.subtask.index: enabled: true - exclude: + metrics_exclude: - strict: "flink.subtask.index-val" flink.task.name: enabled: true - exclude: + metrics_exclude: - strict: "flink.task.name-val" flink.taskmanager.id: enabled: true - exclude: + metrics_exclude: - strict: "flink.taskmanager.id-val" host.name: enabled: true - exclude: + metrics_exclude: - strict: "host.name-val" diff --git a/receiver/gitproviderreceiver/internal/metadata/generated_config.go b/receiver/gitproviderreceiver/internal/metadata/generated_config.go index 9789b978496c..cbd5d30d1920 100644 --- a/receiver/gitproviderreceiver/internal/metadata/generated_config.go +++ b/receiver/gitproviderreceiver/internal/metadata/generated_config.go @@ -65,9 +65,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/gitproviderreceiver/internal/metadata/generated_metrics.go b/receiver/gitproviderreceiver/internal/metadata/generated_metrics.go index 81f6996ebcec..214278c46f7a 100644 --- a/receiver/gitproviderreceiver/internal/metadata/generated_metrics.go +++ b/receiver/gitproviderreceiver/internal/metadata/generated_metrics.go @@ -443,17 +443,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.GitVendorName.Include != nil { - mb.resourceAttributeIncludeFilter["git.vendor.name"] = filter.CreateFilter(mbc.ResourceAttributes.GitVendorName.Include) + if mbc.ResourceAttributes.GitVendorName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["git.vendor.name"] = filter.CreateFilter(mbc.ResourceAttributes.GitVendorName.MetricsInclude) } - if mbc.ResourceAttributes.GitVendorName.Exclude != nil { - mb.resourceAttributeExcludeFilter["git.vendor.name"] = filter.CreateFilter(mbc.ResourceAttributes.GitVendorName.Exclude) + if mbc.ResourceAttributes.GitVendorName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["git.vendor.name"] = filter.CreateFilter(mbc.ResourceAttributes.GitVendorName.MetricsExclude) } - if mbc.ResourceAttributes.OrganizationName.Include != nil { - mb.resourceAttributeIncludeFilter["organization.name"] = filter.CreateFilter(mbc.ResourceAttributes.OrganizationName.Include) + if mbc.ResourceAttributes.OrganizationName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["organization.name"] = filter.CreateFilter(mbc.ResourceAttributes.OrganizationName.MetricsInclude) } - if mbc.ResourceAttributes.OrganizationName.Exclude != nil { - mb.resourceAttributeExcludeFilter["organization.name"] = filter.CreateFilter(mbc.ResourceAttributes.OrganizationName.Exclude) + if mbc.ResourceAttributes.OrganizationName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["organization.name"] = filter.CreateFilter(mbc.ResourceAttributes.OrganizationName.MetricsExclude) } for _, op := range options { diff --git a/receiver/gitproviderreceiver/internal/metadata/testdata/config.yaml b/receiver/gitproviderreceiver/internal/metadata/testdata/config.yaml index 1aefe5883c32..24cb3661783c 100644 --- a/receiver/gitproviderreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/gitproviderreceiver/internal/metadata/testdata/config.yaml @@ -45,19 +45,19 @@ filter_set_include: resource_attributes: git.vendor.name: enabled: true - include: + metrics_include: - regexp: ".*" organization.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: git.vendor.name: enabled: true - exclude: + metrics_exclude: - strict: "git.vendor.name-val" organization.name: enabled: true - exclude: + metrics_exclude: - strict: "organization.name-val" diff --git a/receiver/haproxyreceiver/internal/metadata/generated_config.go b/receiver/haproxyreceiver/internal/metadata/generated_config.go index 59a98ead7a85..ac09b988bf7d 100644 --- a/receiver/haproxyreceiver/internal/metadata/generated_config.go +++ b/receiver/haproxyreceiver/internal/metadata/generated_config.go @@ -141,9 +141,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/haproxyreceiver/internal/metadata/generated_metrics.go b/receiver/haproxyreceiver/internal/metadata/generated_metrics.go index 6bc9958df4ec..c7ec8e99d77b 100644 --- a/receiver/haproxyreceiver/internal/metadata/generated_metrics.go +++ b/receiver/haproxyreceiver/internal/metadata/generated_metrics.go @@ -1457,23 +1457,23 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.HaproxyAddr.Include != nil { - mb.resourceAttributeIncludeFilter["haproxy.addr"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyAddr.Include) + if mbc.ResourceAttributes.HaproxyAddr.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["haproxy.addr"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyAddr.MetricsInclude) } - if mbc.ResourceAttributes.HaproxyAddr.Exclude != nil { - mb.resourceAttributeExcludeFilter["haproxy.addr"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyAddr.Exclude) + if mbc.ResourceAttributes.HaproxyAddr.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["haproxy.addr"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyAddr.MetricsExclude) } - if mbc.ResourceAttributes.HaproxyProxyName.Include != nil { - mb.resourceAttributeIncludeFilter["haproxy.proxy_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyProxyName.Include) + if mbc.ResourceAttributes.HaproxyProxyName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["haproxy.proxy_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyProxyName.MetricsInclude) } - if mbc.ResourceAttributes.HaproxyProxyName.Exclude != nil { - mb.resourceAttributeExcludeFilter["haproxy.proxy_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyProxyName.Exclude) + if mbc.ResourceAttributes.HaproxyProxyName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["haproxy.proxy_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyProxyName.MetricsExclude) } - if mbc.ResourceAttributes.HaproxyServiceName.Include != nil { - mb.resourceAttributeIncludeFilter["haproxy.service_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyServiceName.Include) + if mbc.ResourceAttributes.HaproxyServiceName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["haproxy.service_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyServiceName.MetricsInclude) } - if mbc.ResourceAttributes.HaproxyServiceName.Exclude != nil { - mb.resourceAttributeExcludeFilter["haproxy.service_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyServiceName.Exclude) + if mbc.ResourceAttributes.HaproxyServiceName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["haproxy.service_name"] = filter.CreateFilter(mbc.ResourceAttributes.HaproxyServiceName.MetricsExclude) } for _, op := range options { diff --git a/receiver/haproxyreceiver/internal/metadata/testdata/config.yaml b/receiver/haproxyreceiver/internal/metadata/testdata/config.yaml index 609869b001ca..dbe6f19412df 100644 --- a/receiver/haproxyreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/haproxyreceiver/internal/metadata/testdata/config.yaml @@ -125,27 +125,27 @@ filter_set_include: resource_attributes: haproxy.addr: enabled: true - include: + metrics_include: - regexp: ".*" haproxy.proxy_name: enabled: true - include: + metrics_include: - regexp: ".*" haproxy.service_name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: haproxy.addr: enabled: true - exclude: + metrics_exclude: - strict: "haproxy.addr-val" haproxy.proxy_name: enabled: true - exclude: + metrics_exclude: - strict: "haproxy.proxy_name-val" haproxy.service_name: enabled: true - exclude: + metrics_exclude: - strict: "haproxy.service_name-val" diff --git a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_config.go b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_config.go index ea85a759e8ff..a02f6882b28e 100644 --- a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_config.go +++ b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_config.go @@ -89,9 +89,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_metrics.go b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_metrics.go index 16b50ca8497e..32e91fbb4167 100644 --- a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_metrics.go +++ b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/generated_metrics.go @@ -849,53 +849,53 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ProcessCgroup.Include != nil { - mb.resourceAttributeIncludeFilter["process.cgroup"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCgroup.Include) + if mbc.ResourceAttributes.ProcessCgroup.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.cgroup"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCgroup.MetricsInclude) } - if mbc.ResourceAttributes.ProcessCgroup.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.cgroup"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCgroup.Exclude) + if mbc.ResourceAttributes.ProcessCgroup.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.cgroup"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCgroup.MetricsExclude) } - if mbc.ResourceAttributes.ProcessCommand.Include != nil { - mb.resourceAttributeIncludeFilter["process.command"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommand.Include) + if mbc.ResourceAttributes.ProcessCommand.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.command"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommand.MetricsInclude) } - if mbc.ResourceAttributes.ProcessCommand.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.command"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommand.Exclude) + if mbc.ResourceAttributes.ProcessCommand.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.command"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommand.MetricsExclude) } - if mbc.ResourceAttributes.ProcessCommandLine.Include != nil { - mb.resourceAttributeIncludeFilter["process.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommandLine.Include) + if mbc.ResourceAttributes.ProcessCommandLine.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommandLine.MetricsInclude) } - if mbc.ResourceAttributes.ProcessCommandLine.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommandLine.Exclude) + if mbc.ResourceAttributes.ProcessCommandLine.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.command_line"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessCommandLine.MetricsExclude) } - if mbc.ResourceAttributes.ProcessExecutableName.Include != nil { - mb.resourceAttributeIncludeFilter["process.executable.name"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutableName.Include) + if mbc.ResourceAttributes.ProcessExecutableName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.executable.name"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutableName.MetricsInclude) } - if mbc.ResourceAttributes.ProcessExecutableName.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.executable.name"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutableName.Exclude) + if mbc.ResourceAttributes.ProcessExecutableName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.executable.name"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutableName.MetricsExclude) } - if mbc.ResourceAttributes.ProcessExecutablePath.Include != nil { - mb.resourceAttributeIncludeFilter["process.executable.path"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutablePath.Include) + if mbc.ResourceAttributes.ProcessExecutablePath.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.executable.path"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutablePath.MetricsInclude) } - if mbc.ResourceAttributes.ProcessExecutablePath.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.executable.path"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutablePath.Exclude) + if mbc.ResourceAttributes.ProcessExecutablePath.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.executable.path"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessExecutablePath.MetricsExclude) } - if mbc.ResourceAttributes.ProcessOwner.Include != nil { - mb.resourceAttributeIncludeFilter["process.owner"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessOwner.Include) + if mbc.ResourceAttributes.ProcessOwner.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.owner"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessOwner.MetricsInclude) } - if mbc.ResourceAttributes.ProcessOwner.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.owner"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessOwner.Exclude) + if mbc.ResourceAttributes.ProcessOwner.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.owner"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessOwner.MetricsExclude) } - if mbc.ResourceAttributes.ProcessParentPid.Include != nil { - mb.resourceAttributeIncludeFilter["process.parent_pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessParentPid.Include) + if mbc.ResourceAttributes.ProcessParentPid.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.parent_pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessParentPid.MetricsInclude) } - if mbc.ResourceAttributes.ProcessParentPid.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.parent_pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessParentPid.Exclude) + if mbc.ResourceAttributes.ProcessParentPid.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.parent_pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessParentPid.MetricsExclude) } - if mbc.ResourceAttributes.ProcessPid.Include != nil { - mb.resourceAttributeIncludeFilter["process.pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessPid.Include) + if mbc.ResourceAttributes.ProcessPid.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["process.pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessPid.MetricsInclude) } - if mbc.ResourceAttributes.ProcessPid.Exclude != nil { - mb.resourceAttributeExcludeFilter["process.pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessPid.Exclude) + if mbc.ResourceAttributes.ProcessPid.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["process.pid"] = filter.CreateFilter(mbc.ResourceAttributes.ProcessPid.MetricsExclude) } for _, op := range options { diff --git a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/testdata/config.yaml b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/testdata/config.yaml index bad7a9748252..6661ee6f514b 100644 --- a/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/testdata/config.yaml +++ b/receiver/hostmetricsreceiver/internal/scraper/processscraper/internal/metadata/testdata/config.yaml @@ -93,67 +93,67 @@ filter_set_include: resource_attributes: process.cgroup: enabled: true - include: + metrics_include: - regexp: ".*" process.command: enabled: true - include: + metrics_include: - regexp: ".*" process.command_line: enabled: true - include: + metrics_include: - regexp: ".*" process.executable.name: enabled: true - include: + metrics_include: - regexp: ".*" process.executable.path: enabled: true - include: + metrics_include: - regexp: ".*" process.owner: enabled: true - include: + metrics_include: - regexp: ".*" process.parent_pid: enabled: true - include: + metrics_include: - regexp: ".*" process.pid: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: process.cgroup: enabled: true - exclude: + metrics_exclude: - strict: "process.cgroup-val" process.command: enabled: true - exclude: + metrics_exclude: - strict: "process.command-val" process.command_line: enabled: true - exclude: + metrics_exclude: - strict: "process.command_line-val" process.executable.name: enabled: true - exclude: + metrics_exclude: - strict: "process.executable.name-val" process.executable.path: enabled: true - exclude: + metrics_exclude: - strict: "process.executable.path-val" process.owner: enabled: true - exclude: + metrics_exclude: - strict: "process.owner-val" process.parent_pid: enabled: true - exclude: + metrics_exclude: - regexp: ".*" process.pid: enabled: true - exclude: + metrics_exclude: - regexp: ".*" diff --git a/receiver/iisreceiver/internal/metadata/generated_config.go b/receiver/iisreceiver/internal/metadata/generated_config.go index a87635777537..8f3c2da03905 100644 --- a/receiver/iisreceiver/internal/metadata/generated_config.go +++ b/receiver/iisreceiver/internal/metadata/generated_config.go @@ -85,9 +85,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/iisreceiver/internal/metadata/generated_metrics.go b/receiver/iisreceiver/internal/metadata/generated_metrics.go index 9695e11d5aa2..54b9f772589e 100644 --- a/receiver/iisreceiver/internal/metadata/generated_metrics.go +++ b/receiver/iisreceiver/internal/metadata/generated_metrics.go @@ -753,17 +753,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.IisApplicationPool.Include != nil { - mb.resourceAttributeIncludeFilter["iis.application_pool"] = filter.CreateFilter(mbc.ResourceAttributes.IisApplicationPool.Include) + if mbc.ResourceAttributes.IisApplicationPool.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["iis.application_pool"] = filter.CreateFilter(mbc.ResourceAttributes.IisApplicationPool.MetricsInclude) } - if mbc.ResourceAttributes.IisApplicationPool.Exclude != nil { - mb.resourceAttributeExcludeFilter["iis.application_pool"] = filter.CreateFilter(mbc.ResourceAttributes.IisApplicationPool.Exclude) + if mbc.ResourceAttributes.IisApplicationPool.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["iis.application_pool"] = filter.CreateFilter(mbc.ResourceAttributes.IisApplicationPool.MetricsExclude) } - if mbc.ResourceAttributes.IisSite.Include != nil { - mb.resourceAttributeIncludeFilter["iis.site"] = filter.CreateFilter(mbc.ResourceAttributes.IisSite.Include) + if mbc.ResourceAttributes.IisSite.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["iis.site"] = filter.CreateFilter(mbc.ResourceAttributes.IisSite.MetricsInclude) } - if mbc.ResourceAttributes.IisSite.Exclude != nil { - mb.resourceAttributeExcludeFilter["iis.site"] = filter.CreateFilter(mbc.ResourceAttributes.IisSite.Exclude) + if mbc.ResourceAttributes.IisSite.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["iis.site"] = filter.CreateFilter(mbc.ResourceAttributes.IisSite.MetricsExclude) } for _, op := range options { diff --git a/receiver/iisreceiver/internal/metadata/testdata/config.yaml b/receiver/iisreceiver/internal/metadata/testdata/config.yaml index dec4f4ad8c21..3354c9fe4742 100644 --- a/receiver/iisreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/iisreceiver/internal/metadata/testdata/config.yaml @@ -65,19 +65,19 @@ filter_set_include: resource_attributes: iis.application_pool: enabled: true - include: + metrics_include: - regexp: ".*" iis.site: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: iis.application_pool: enabled: true - exclude: + metrics_exclude: - strict: "iis.application_pool-val" iis.site: enabled: true - exclude: + metrics_exclude: - strict: "iis.site-val" diff --git a/receiver/k8sclusterreceiver/internal/metadata/generated_config.go b/receiver/k8sclusterreceiver/internal/metadata/generated_config.go index 22a1c8703bf6..114f0b37ae35 100644 --- a/receiver/k8sclusterreceiver/internal/metadata/generated_config.go +++ b/receiver/k8sclusterreceiver/internal/metadata/generated_config.go @@ -213,9 +213,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/k8sclusterreceiver/internal/metadata/generated_metrics.go b/receiver/k8sclusterreceiver/internal/metadata/generated_metrics.go index 08d98364f951..1fd9d95ba29e 100644 --- a/receiver/k8sclusterreceiver/internal/metadata/generated_metrics.go +++ b/receiver/k8sclusterreceiver/internal/metadata/generated_metrics.go @@ -2304,227 +2304,227 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ContainerID.Include != nil { - mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Include) + if mbc.ResourceAttributes.ContainerID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsInclude) } - if mbc.ResourceAttributes.ContainerID.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Exclude) + if mbc.ResourceAttributes.ContainerID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsExclude) } - if mbc.ResourceAttributes.ContainerImageName.Include != nil { - mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Include) + if mbc.ResourceAttributes.ContainerImageName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsInclude) } - if mbc.ResourceAttributes.ContainerImageName.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Exclude) + if mbc.ResourceAttributes.ContainerImageName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsExclude) } - if mbc.ResourceAttributes.ContainerImageTag.Include != nil { - mb.resourceAttributeIncludeFilter["container.image.tag"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageTag.Include) + if mbc.ResourceAttributes.ContainerImageTag.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.image.tag"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageTag.MetricsInclude) } - if mbc.ResourceAttributes.ContainerImageTag.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.image.tag"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageTag.Exclude) + if mbc.ResourceAttributes.ContainerImageTag.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.image.tag"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageTag.MetricsExclude) } - if mbc.ResourceAttributes.ContainerRuntime.Include != nil { - mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Include) + if mbc.ResourceAttributes.ContainerRuntime.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsInclude) } - if mbc.ResourceAttributes.ContainerRuntime.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Exclude) + if mbc.ResourceAttributes.ContainerRuntime.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsExclude) } - if mbc.ResourceAttributes.ContainerRuntimeVersion.Include != nil { - mb.resourceAttributeIncludeFilter["container.runtime.version"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntimeVersion.Include) + if mbc.ResourceAttributes.ContainerRuntimeVersion.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.runtime.version"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntimeVersion.MetricsInclude) } - if mbc.ResourceAttributes.ContainerRuntimeVersion.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.runtime.version"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntimeVersion.Exclude) + if mbc.ResourceAttributes.ContainerRuntimeVersion.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.runtime.version"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntimeVersion.MetricsExclude) } - if mbc.ResourceAttributes.K8sContainerName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.Include) + if mbc.ResourceAttributes.K8sContainerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.MetricsInclude) } - if mbc.ResourceAttributes.K8sContainerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.Exclude) + if mbc.ResourceAttributes.K8sContainerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.MetricsExclude) } - if mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.container.status.last_terminated_reason"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.Include) + if mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.container.status.last_terminated_reason"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.MetricsInclude) } - if mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.container.status.last_terminated_reason"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.Exclude) + if mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.container.status.last_terminated_reason"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerStatusLastTerminatedReason.MetricsExclude) } - if mbc.ResourceAttributes.K8sCronjobName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.cronjob.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobName.Include) + if mbc.ResourceAttributes.K8sCronjobName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.cronjob.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobName.MetricsInclude) } - if mbc.ResourceAttributes.K8sCronjobName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.cronjob.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobName.Exclude) + if mbc.ResourceAttributes.K8sCronjobName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.cronjob.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobName.MetricsExclude) } - if mbc.ResourceAttributes.K8sCronjobUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.cronjob.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobUID.Include) + if mbc.ResourceAttributes.K8sCronjobUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.cronjob.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sCronjobUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.cronjob.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobUID.Exclude) + if mbc.ResourceAttributes.K8sCronjobUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.cronjob.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sCronjobUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sDaemonsetName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.daemonset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetName.Include) + if mbc.ResourceAttributes.K8sDaemonsetName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.daemonset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetName.MetricsInclude) } - if mbc.ResourceAttributes.K8sDaemonsetName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.daemonset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetName.Exclude) + if mbc.ResourceAttributes.K8sDaemonsetName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.daemonset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetName.MetricsExclude) } - if mbc.ResourceAttributes.K8sDaemonsetUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.daemonset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetUID.Include) + if mbc.ResourceAttributes.K8sDaemonsetUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.daemonset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sDaemonsetUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.daemonset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetUID.Exclude) + if mbc.ResourceAttributes.K8sDaemonsetUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.daemonset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDaemonsetUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sDeploymentName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.deployment.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentName.Include) + if mbc.ResourceAttributes.K8sDeploymentName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.deployment.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentName.MetricsInclude) } - if mbc.ResourceAttributes.K8sDeploymentName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.deployment.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentName.Exclude) + if mbc.ResourceAttributes.K8sDeploymentName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.deployment.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentName.MetricsExclude) } - if mbc.ResourceAttributes.K8sDeploymentUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.deployment.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentUID.Include) + if mbc.ResourceAttributes.K8sDeploymentUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.deployment.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sDeploymentUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.deployment.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentUID.Exclude) + if mbc.ResourceAttributes.K8sDeploymentUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.deployment.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sDeploymentUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sHpaName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.hpa.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaName.Include) + if mbc.ResourceAttributes.K8sHpaName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.hpa.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaName.MetricsInclude) } - if mbc.ResourceAttributes.K8sHpaName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.hpa.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaName.Exclude) + if mbc.ResourceAttributes.K8sHpaName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.hpa.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaName.MetricsExclude) } - if mbc.ResourceAttributes.K8sHpaUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.hpa.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaUID.Include) + if mbc.ResourceAttributes.K8sHpaUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.hpa.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sHpaUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.hpa.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaUID.Exclude) + if mbc.ResourceAttributes.K8sHpaUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.hpa.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sHpaUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sJobName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobName.Include) + if mbc.ResourceAttributes.K8sJobName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobName.MetricsInclude) } - if mbc.ResourceAttributes.K8sJobName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobName.Exclude) + if mbc.ResourceAttributes.K8sJobName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.job.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobName.MetricsExclude) } - if mbc.ResourceAttributes.K8sJobUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.job.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobUID.Include) + if mbc.ResourceAttributes.K8sJobUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.job.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sJobUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.job.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobUID.Exclude) + if mbc.ResourceAttributes.K8sJobUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.job.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sJobUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sKubeletVersion.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.kubelet.version"] = filter.CreateFilter(mbc.ResourceAttributes.K8sKubeletVersion.Include) + if mbc.ResourceAttributes.K8sKubeletVersion.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.kubelet.version"] = filter.CreateFilter(mbc.ResourceAttributes.K8sKubeletVersion.MetricsInclude) } - if mbc.ResourceAttributes.K8sKubeletVersion.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.kubelet.version"] = filter.CreateFilter(mbc.ResourceAttributes.K8sKubeletVersion.Exclude) + if mbc.ResourceAttributes.K8sKubeletVersion.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.kubelet.version"] = filter.CreateFilter(mbc.ResourceAttributes.K8sKubeletVersion.MetricsExclude) } - if mbc.ResourceAttributes.K8sNamespaceName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.Include) + if mbc.ResourceAttributes.K8sNamespaceName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.MetricsInclude) } - if mbc.ResourceAttributes.K8sNamespaceName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.Exclude) + if mbc.ResourceAttributes.K8sNamespaceName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.MetricsExclude) } - if mbc.ResourceAttributes.K8sNamespaceUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.namespace.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceUID.Include) + if mbc.ResourceAttributes.K8sNamespaceUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.namespace.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sNamespaceUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.namespace.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceUID.Exclude) + if mbc.ResourceAttributes.K8sNamespaceUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.namespace.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.Include) + if mbc.ResourceAttributes.K8sNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.MetricsInclude) } - if mbc.ResourceAttributes.K8sNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.Exclude) + if mbc.ResourceAttributes.K8sNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.MetricsExclude) } - if mbc.ResourceAttributes.K8sNodeUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.node.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeUID.Include) + if mbc.ResourceAttributes.K8sNodeUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.node.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sNodeUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.node.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeUID.Exclude) + if mbc.ResourceAttributes.K8sNodeUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.node.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sPodName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.Include) + if mbc.ResourceAttributes.K8sPodName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.MetricsInclude) } - if mbc.ResourceAttributes.K8sPodName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.Exclude) + if mbc.ResourceAttributes.K8sPodName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.MetricsExclude) } - if mbc.ResourceAttributes.K8sPodQosClass.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.pod.qos_class"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodQosClass.Include) + if mbc.ResourceAttributes.K8sPodQosClass.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.pod.qos_class"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodQosClass.MetricsInclude) } - if mbc.ResourceAttributes.K8sPodQosClass.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.pod.qos_class"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodQosClass.Exclude) + if mbc.ResourceAttributes.K8sPodQosClass.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.pod.qos_class"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodQosClass.MetricsExclude) } - if mbc.ResourceAttributes.K8sPodUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.Include) + if mbc.ResourceAttributes.K8sPodUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sPodUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.Exclude) + if mbc.ResourceAttributes.K8sPodUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sReplicasetName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.replicaset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetName.Include) + if mbc.ResourceAttributes.K8sReplicasetName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.replicaset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetName.MetricsInclude) } - if mbc.ResourceAttributes.K8sReplicasetName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.replicaset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetName.Exclude) + if mbc.ResourceAttributes.K8sReplicasetName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.replicaset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetName.MetricsExclude) } - if mbc.ResourceAttributes.K8sReplicasetUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.replicaset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetUID.Include) + if mbc.ResourceAttributes.K8sReplicasetUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.replicaset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sReplicasetUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.replicaset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetUID.Exclude) + if mbc.ResourceAttributes.K8sReplicasetUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.replicaset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicasetUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sReplicationcontrollerName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.replicationcontroller.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerName.Include) + if mbc.ResourceAttributes.K8sReplicationcontrollerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.replicationcontroller.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerName.MetricsInclude) } - if mbc.ResourceAttributes.K8sReplicationcontrollerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.replicationcontroller.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerName.Exclude) + if mbc.ResourceAttributes.K8sReplicationcontrollerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.replicationcontroller.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerName.MetricsExclude) } - if mbc.ResourceAttributes.K8sReplicationcontrollerUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.replicationcontroller.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerUID.Include) + if mbc.ResourceAttributes.K8sReplicationcontrollerUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.replicationcontroller.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sReplicationcontrollerUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.replicationcontroller.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerUID.Exclude) + if mbc.ResourceAttributes.K8sReplicationcontrollerUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.replicationcontroller.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sReplicationcontrollerUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sResourcequotaName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.resourcequota.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaName.Include) + if mbc.ResourceAttributes.K8sResourcequotaName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.resourcequota.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaName.MetricsInclude) } - if mbc.ResourceAttributes.K8sResourcequotaName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.resourcequota.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaName.Exclude) + if mbc.ResourceAttributes.K8sResourcequotaName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.resourcequota.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaName.MetricsExclude) } - if mbc.ResourceAttributes.K8sResourcequotaUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.resourcequota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaUID.Include) + if mbc.ResourceAttributes.K8sResourcequotaUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.resourcequota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sResourcequotaUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.resourcequota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaUID.Exclude) + if mbc.ResourceAttributes.K8sResourcequotaUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.resourcequota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sResourcequotaUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sStatefulsetName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.statefulset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetName.Include) + if mbc.ResourceAttributes.K8sStatefulsetName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.statefulset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetName.MetricsInclude) } - if mbc.ResourceAttributes.K8sStatefulsetName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.statefulset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetName.Exclude) + if mbc.ResourceAttributes.K8sStatefulsetName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.statefulset.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetName.MetricsExclude) } - if mbc.ResourceAttributes.K8sStatefulsetUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.statefulset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetUID.Include) + if mbc.ResourceAttributes.K8sStatefulsetUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.statefulset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sStatefulsetUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.statefulset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetUID.Exclude) + if mbc.ResourceAttributes.K8sStatefulsetUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.statefulset.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sStatefulsetUID.MetricsExclude) } - if mbc.ResourceAttributes.OpenshiftClusterquotaName.Include != nil { - mb.resourceAttributeIncludeFilter["openshift.clusterquota.name"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaName.Include) + if mbc.ResourceAttributes.OpenshiftClusterquotaName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["openshift.clusterquota.name"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaName.MetricsInclude) } - if mbc.ResourceAttributes.OpenshiftClusterquotaName.Exclude != nil { - mb.resourceAttributeExcludeFilter["openshift.clusterquota.name"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaName.Exclude) + if mbc.ResourceAttributes.OpenshiftClusterquotaName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["openshift.clusterquota.name"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaName.MetricsExclude) } - if mbc.ResourceAttributes.OpenshiftClusterquotaUID.Include != nil { - mb.resourceAttributeIncludeFilter["openshift.clusterquota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaUID.Include) + if mbc.ResourceAttributes.OpenshiftClusterquotaUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["openshift.clusterquota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaUID.MetricsInclude) } - if mbc.ResourceAttributes.OpenshiftClusterquotaUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["openshift.clusterquota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaUID.Exclude) + if mbc.ResourceAttributes.OpenshiftClusterquotaUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["openshift.clusterquota.uid"] = filter.CreateFilter(mbc.ResourceAttributes.OpenshiftClusterquotaUID.MetricsExclude) } - if mbc.ResourceAttributes.OsDescription.Include != nil { - mb.resourceAttributeIncludeFilter["os.description"] = filter.CreateFilter(mbc.ResourceAttributes.OsDescription.Include) + if mbc.ResourceAttributes.OsDescription.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["os.description"] = filter.CreateFilter(mbc.ResourceAttributes.OsDescription.MetricsInclude) } - if mbc.ResourceAttributes.OsDescription.Exclude != nil { - mb.resourceAttributeExcludeFilter["os.description"] = filter.CreateFilter(mbc.ResourceAttributes.OsDescription.Exclude) + if mbc.ResourceAttributes.OsDescription.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["os.description"] = filter.CreateFilter(mbc.ResourceAttributes.OsDescription.MetricsExclude) } - if mbc.ResourceAttributes.OsType.Include != nil { - mb.resourceAttributeIncludeFilter["os.type"] = filter.CreateFilter(mbc.ResourceAttributes.OsType.Include) + if mbc.ResourceAttributes.OsType.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["os.type"] = filter.CreateFilter(mbc.ResourceAttributes.OsType.MetricsInclude) } - if mbc.ResourceAttributes.OsType.Exclude != nil { - mb.resourceAttributeExcludeFilter["os.type"] = filter.CreateFilter(mbc.ResourceAttributes.OsType.Exclude) + if mbc.ResourceAttributes.OsType.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["os.type"] = filter.CreateFilter(mbc.ResourceAttributes.OsType.MetricsExclude) } for _, op := range options { diff --git a/receiver/k8sclusterreceiver/internal/metadata/testdata/config.yaml b/receiver/k8sclusterreceiver/internal/metadata/testdata/config.yaml index 5e51dfc4a10c..ead9483567f9 100644 --- a/receiver/k8sclusterreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/k8sclusterreceiver/internal/metadata/testdata/config.yaml @@ -333,299 +333,299 @@ filter_set_include: resource_attributes: container.id: enabled: true - include: + metrics_include: - regexp: ".*" container.image.name: enabled: true - include: + metrics_include: - regexp: ".*" container.image.tag: enabled: true - include: + metrics_include: - regexp: ".*" container.runtime: enabled: true - include: + metrics_include: - regexp: ".*" container.runtime.version: enabled: true - include: + metrics_include: - regexp: ".*" k8s.container.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.container.status.last_terminated_reason: enabled: true - include: + metrics_include: - regexp: ".*" k8s.cronjob.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.cronjob.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.daemonset.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.daemonset.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.deployment.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.deployment.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.hpa.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.hpa.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.job.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.job.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.kubelet.version: enabled: true - include: + metrics_include: - regexp: ".*" k8s.namespace.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.namespace.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.node.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.node.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.pod.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.pod.qos_class: enabled: true - include: + metrics_include: - regexp: ".*" k8s.pod.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.replicaset.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.replicaset.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.replicationcontroller.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.replicationcontroller.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.resourcequota.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.resourcequota.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.statefulset.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.statefulset.uid: enabled: true - include: + metrics_include: - regexp: ".*" openshift.clusterquota.name: enabled: true - include: + metrics_include: - regexp: ".*" openshift.clusterquota.uid: enabled: true - include: + metrics_include: - regexp: ".*" os.description: enabled: true - include: + metrics_include: - regexp: ".*" os.type: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: container.id: enabled: true - exclude: + metrics_exclude: - strict: "container.id-val" container.image.name: enabled: true - exclude: + metrics_exclude: - strict: "container.image.name-val" container.image.tag: enabled: true - exclude: + metrics_exclude: - strict: "container.image.tag-val" container.runtime: enabled: true - exclude: + metrics_exclude: - strict: "container.runtime-val" container.runtime.version: enabled: true - exclude: + metrics_exclude: - strict: "container.runtime.version-val" k8s.container.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.container.name-val" k8s.container.status.last_terminated_reason: enabled: true - exclude: + metrics_exclude: - strict: "k8s.container.status.last_terminated_reason-val" k8s.cronjob.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.cronjob.name-val" k8s.cronjob.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.cronjob.uid-val" k8s.daemonset.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.daemonset.name-val" k8s.daemonset.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.daemonset.uid-val" k8s.deployment.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.deployment.name-val" k8s.deployment.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.deployment.uid-val" k8s.hpa.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.hpa.name-val" k8s.hpa.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.hpa.uid-val" k8s.job.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.job.name-val" k8s.job.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.job.uid-val" k8s.kubelet.version: enabled: true - exclude: + metrics_exclude: - strict: "k8s.kubelet.version-val" k8s.namespace.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.namespace.name-val" k8s.namespace.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.namespace.uid-val" k8s.node.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.node.name-val" k8s.node.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.node.uid-val" k8s.pod.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.pod.name-val" k8s.pod.qos_class: enabled: true - exclude: + metrics_exclude: - strict: "k8s.pod.qos_class-val" k8s.pod.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.pod.uid-val" k8s.replicaset.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.replicaset.name-val" k8s.replicaset.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.replicaset.uid-val" k8s.replicationcontroller.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.replicationcontroller.name-val" k8s.replicationcontroller.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.replicationcontroller.uid-val" k8s.resourcequota.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.resourcequota.name-val" k8s.resourcequota.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.resourcequota.uid-val" k8s.statefulset.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.statefulset.name-val" k8s.statefulset.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.statefulset.uid-val" openshift.clusterquota.name: enabled: true - exclude: + metrics_exclude: - strict: "openshift.clusterquota.name-val" openshift.clusterquota.uid: enabled: true - exclude: + metrics_exclude: - strict: "openshift.clusterquota.uid-val" os.description: enabled: true - exclude: + metrics_exclude: - strict: "os.description-val" os.type: enabled: true - exclude: + metrics_exclude: - strict: "os.type-val" diff --git a/receiver/kubeletstatsreceiver/internal/metadata/generated_config.go b/receiver/kubeletstatsreceiver/internal/metadata/generated_config.go index 6f1f091fbf15..b5244d545cfc 100644 --- a/receiver/kubeletstatsreceiver/internal/metadata/generated_config.go +++ b/receiver/kubeletstatsreceiver/internal/metadata/generated_config.go @@ -261,9 +261,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/kubeletstatsreceiver/internal/metadata/generated_metrics.go b/receiver/kubeletstatsreceiver/internal/metadata/generated_metrics.go index 63ed8fb7a32b..b966d529769b 100644 --- a/receiver/kubeletstatsreceiver/internal/metadata/generated_metrics.go +++ b/receiver/kubeletstatsreceiver/internal/metadata/generated_metrics.go @@ -2966,95 +2966,95 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.AwsVolumeID.Include != nil { - mb.resourceAttributeIncludeFilter["aws.volume.id"] = filter.CreateFilter(mbc.ResourceAttributes.AwsVolumeID.Include) + if mbc.ResourceAttributes.AwsVolumeID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["aws.volume.id"] = filter.CreateFilter(mbc.ResourceAttributes.AwsVolumeID.MetricsInclude) } - if mbc.ResourceAttributes.AwsVolumeID.Exclude != nil { - mb.resourceAttributeExcludeFilter["aws.volume.id"] = filter.CreateFilter(mbc.ResourceAttributes.AwsVolumeID.Exclude) + if mbc.ResourceAttributes.AwsVolumeID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["aws.volume.id"] = filter.CreateFilter(mbc.ResourceAttributes.AwsVolumeID.MetricsExclude) } - if mbc.ResourceAttributes.ContainerID.Include != nil { - mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Include) + if mbc.ResourceAttributes.ContainerID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsInclude) } - if mbc.ResourceAttributes.ContainerID.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Exclude) + if mbc.ResourceAttributes.ContainerID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsExclude) } - if mbc.ResourceAttributes.FsType.Include != nil { - mb.resourceAttributeIncludeFilter["fs.type"] = filter.CreateFilter(mbc.ResourceAttributes.FsType.Include) + if mbc.ResourceAttributes.FsType.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["fs.type"] = filter.CreateFilter(mbc.ResourceAttributes.FsType.MetricsInclude) } - if mbc.ResourceAttributes.FsType.Exclude != nil { - mb.resourceAttributeExcludeFilter["fs.type"] = filter.CreateFilter(mbc.ResourceAttributes.FsType.Exclude) + if mbc.ResourceAttributes.FsType.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["fs.type"] = filter.CreateFilter(mbc.ResourceAttributes.FsType.MetricsExclude) } - if mbc.ResourceAttributes.GcePdName.Include != nil { - mb.resourceAttributeIncludeFilter["gce.pd.name"] = filter.CreateFilter(mbc.ResourceAttributes.GcePdName.Include) + if mbc.ResourceAttributes.GcePdName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["gce.pd.name"] = filter.CreateFilter(mbc.ResourceAttributes.GcePdName.MetricsInclude) } - if mbc.ResourceAttributes.GcePdName.Exclude != nil { - mb.resourceAttributeExcludeFilter["gce.pd.name"] = filter.CreateFilter(mbc.ResourceAttributes.GcePdName.Exclude) + if mbc.ResourceAttributes.GcePdName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["gce.pd.name"] = filter.CreateFilter(mbc.ResourceAttributes.GcePdName.MetricsExclude) } - if mbc.ResourceAttributes.GlusterfsEndpointsName.Include != nil { - mb.resourceAttributeIncludeFilter["glusterfs.endpoints.name"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsEndpointsName.Include) + if mbc.ResourceAttributes.GlusterfsEndpointsName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["glusterfs.endpoints.name"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsEndpointsName.MetricsInclude) } - if mbc.ResourceAttributes.GlusterfsEndpointsName.Exclude != nil { - mb.resourceAttributeExcludeFilter["glusterfs.endpoints.name"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsEndpointsName.Exclude) + if mbc.ResourceAttributes.GlusterfsEndpointsName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["glusterfs.endpoints.name"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsEndpointsName.MetricsExclude) } - if mbc.ResourceAttributes.GlusterfsPath.Include != nil { - mb.resourceAttributeIncludeFilter["glusterfs.path"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsPath.Include) + if mbc.ResourceAttributes.GlusterfsPath.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["glusterfs.path"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsPath.MetricsInclude) } - if mbc.ResourceAttributes.GlusterfsPath.Exclude != nil { - mb.resourceAttributeExcludeFilter["glusterfs.path"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsPath.Exclude) + if mbc.ResourceAttributes.GlusterfsPath.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["glusterfs.path"] = filter.CreateFilter(mbc.ResourceAttributes.GlusterfsPath.MetricsExclude) } - if mbc.ResourceAttributes.K8sContainerName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.Include) + if mbc.ResourceAttributes.K8sContainerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.MetricsInclude) } - if mbc.ResourceAttributes.K8sContainerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.Exclude) + if mbc.ResourceAttributes.K8sContainerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.container.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sContainerName.MetricsExclude) } - if mbc.ResourceAttributes.K8sNamespaceName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.Include) + if mbc.ResourceAttributes.K8sNamespaceName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.MetricsInclude) } - if mbc.ResourceAttributes.K8sNamespaceName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.Exclude) + if mbc.ResourceAttributes.K8sNamespaceName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.namespace.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNamespaceName.MetricsExclude) } - if mbc.ResourceAttributes.K8sNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.Include) + if mbc.ResourceAttributes.K8sNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.MetricsInclude) } - if mbc.ResourceAttributes.K8sNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.Exclude) + if mbc.ResourceAttributes.K8sNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sNodeName.MetricsExclude) } - if mbc.ResourceAttributes.K8sPersistentvolumeclaimName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.persistentvolumeclaim.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPersistentvolumeclaimName.Include) + if mbc.ResourceAttributes.K8sPersistentvolumeclaimName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.persistentvolumeclaim.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPersistentvolumeclaimName.MetricsInclude) } - if mbc.ResourceAttributes.K8sPersistentvolumeclaimName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.persistentvolumeclaim.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPersistentvolumeclaimName.Exclude) + if mbc.ResourceAttributes.K8sPersistentvolumeclaimName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.persistentvolumeclaim.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPersistentvolumeclaimName.MetricsExclude) } - if mbc.ResourceAttributes.K8sPodName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.Include) + if mbc.ResourceAttributes.K8sPodName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.MetricsInclude) } - if mbc.ResourceAttributes.K8sPodName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.Exclude) + if mbc.ResourceAttributes.K8sPodName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.pod.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodName.MetricsExclude) } - if mbc.ResourceAttributes.K8sPodUID.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.Include) + if mbc.ResourceAttributes.K8sPodUID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.MetricsInclude) } - if mbc.ResourceAttributes.K8sPodUID.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.Exclude) + if mbc.ResourceAttributes.K8sPodUID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.pod.uid"] = filter.CreateFilter(mbc.ResourceAttributes.K8sPodUID.MetricsExclude) } - if mbc.ResourceAttributes.K8sVolumeName.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.volume.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeName.Include) + if mbc.ResourceAttributes.K8sVolumeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.volume.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeName.MetricsInclude) } - if mbc.ResourceAttributes.K8sVolumeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.volume.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeName.Exclude) + if mbc.ResourceAttributes.K8sVolumeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.volume.name"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeName.MetricsExclude) } - if mbc.ResourceAttributes.K8sVolumeType.Include != nil { - mb.resourceAttributeIncludeFilter["k8s.volume.type"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeType.Include) + if mbc.ResourceAttributes.K8sVolumeType.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["k8s.volume.type"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeType.MetricsInclude) } - if mbc.ResourceAttributes.K8sVolumeType.Exclude != nil { - mb.resourceAttributeExcludeFilter["k8s.volume.type"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeType.Exclude) + if mbc.ResourceAttributes.K8sVolumeType.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["k8s.volume.type"] = filter.CreateFilter(mbc.ResourceAttributes.K8sVolumeType.MetricsExclude) } - if mbc.ResourceAttributes.Partition.Include != nil { - mb.resourceAttributeIncludeFilter["partition"] = filter.CreateFilter(mbc.ResourceAttributes.Partition.Include) + if mbc.ResourceAttributes.Partition.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["partition"] = filter.CreateFilter(mbc.ResourceAttributes.Partition.MetricsInclude) } - if mbc.ResourceAttributes.Partition.Exclude != nil { - mb.resourceAttributeExcludeFilter["partition"] = filter.CreateFilter(mbc.ResourceAttributes.Partition.Exclude) + if mbc.ResourceAttributes.Partition.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["partition"] = filter.CreateFilter(mbc.ResourceAttributes.Partition.MetricsExclude) } for _, op := range options { diff --git a/receiver/kubeletstatsreceiver/internal/metadata/testdata/config.yaml b/receiver/kubeletstatsreceiver/internal/metadata/testdata/config.yaml index 3d7947fc5bab..7ad001fc3f89 100644 --- a/receiver/kubeletstatsreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/kubeletstatsreceiver/internal/metadata/testdata/config.yaml @@ -293,123 +293,123 @@ filter_set_include: resource_attributes: aws.volume.id: enabled: true - include: + metrics_include: - regexp: ".*" container.id: enabled: true - include: + metrics_include: - regexp: ".*" fs.type: enabled: true - include: + metrics_include: - regexp: ".*" gce.pd.name: enabled: true - include: + metrics_include: - regexp: ".*" glusterfs.endpoints.name: enabled: true - include: + metrics_include: - regexp: ".*" glusterfs.path: enabled: true - include: + metrics_include: - regexp: ".*" k8s.container.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.namespace.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.node.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.persistentvolumeclaim.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.pod.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.pod.uid: enabled: true - include: + metrics_include: - regexp: ".*" k8s.volume.name: enabled: true - include: + metrics_include: - regexp: ".*" k8s.volume.type: enabled: true - include: + metrics_include: - regexp: ".*" partition: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: aws.volume.id: enabled: true - exclude: + metrics_exclude: - strict: "aws.volume.id-val" container.id: enabled: true - exclude: + metrics_exclude: - strict: "container.id-val" fs.type: enabled: true - exclude: + metrics_exclude: - strict: "fs.type-val" gce.pd.name: enabled: true - exclude: + metrics_exclude: - strict: "gce.pd.name-val" glusterfs.endpoints.name: enabled: true - exclude: + metrics_exclude: - strict: "glusterfs.endpoints.name-val" glusterfs.path: enabled: true - exclude: + metrics_exclude: - strict: "glusterfs.path-val" k8s.container.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.container.name-val" k8s.namespace.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.namespace.name-val" k8s.node.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.node.name-val" k8s.persistentvolumeclaim.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.persistentvolumeclaim.name-val" k8s.pod.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.pod.name-val" k8s.pod.uid: enabled: true - exclude: + metrics_exclude: - strict: "k8s.pod.uid-val" k8s.volume.name: enabled: true - exclude: + metrics_exclude: - strict: "k8s.volume.name-val" k8s.volume.type: enabled: true - exclude: + metrics_exclude: - strict: "k8s.volume.type-val" partition: enabled: true - exclude: + metrics_exclude: - strict: "partition-val" diff --git a/receiver/mongodbatlasreceiver/internal/metadata/generated_config.go b/receiver/mongodbatlasreceiver/internal/metadata/generated_config.go index 7f3dadd30086..46cdab5cd211 100644 --- a/receiver/mongodbatlasreceiver/internal/metadata/generated_config.go +++ b/receiver/mongodbatlasreceiver/internal/metadata/generated_config.go @@ -285,9 +285,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/mongodbatlasreceiver/internal/metadata/generated_metrics.go b/receiver/mongodbatlasreceiver/internal/metadata/generated_metrics.go index 99857e95b3ed..a7fccdc13655 100644 --- a/receiver/mongodbatlasreceiver/internal/metadata/generated_metrics.go +++ b/receiver/mongodbatlasreceiver/internal/metadata/generated_metrics.go @@ -4036,83 +4036,83 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.MongodbAtlasClusterName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasClusterName.Include) + if mbc.ResourceAttributes.MongodbAtlasClusterName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasClusterName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasClusterName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasClusterName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasClusterName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasClusterName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasDbName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.db.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDbName.Include) + if mbc.ResourceAttributes.MongodbAtlasDbName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.db.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDbName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasDbName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.db.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDbName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasDbName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.db.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDbName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasDiskPartition.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.disk.partition"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDiskPartition.Include) + if mbc.ResourceAttributes.MongodbAtlasDiskPartition.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.disk.partition"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDiskPartition.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasDiskPartition.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.disk.partition"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDiskPartition.Exclude) + if mbc.ResourceAttributes.MongodbAtlasDiskPartition.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.disk.partition"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasDiskPartition.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasHostName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasHostName.Include) + if mbc.ResourceAttributes.MongodbAtlasHostName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasHostName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasHostName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasHostName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasHostName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasHostName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasOrgName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.org_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasOrgName.Include) + if mbc.ResourceAttributes.MongodbAtlasOrgName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.org_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasOrgName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasOrgName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.org_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasOrgName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasOrgName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.org_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasOrgName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessID.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.process.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessID.Include) + if mbc.ResourceAttributes.MongodbAtlasProcessID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.process.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessID.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessID.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.process.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessID.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProcessID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.process.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessID.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessPort.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.process.port"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessPort.Include) + if mbc.ResourceAttributes.MongodbAtlasProcessPort.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.process.port"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessPort.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessPort.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.process.port"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessPort.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProcessPort.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.process.port"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessPort.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessTypeName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.process.type_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessTypeName.Include) + if mbc.ResourceAttributes.MongodbAtlasProcessTypeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.process.type_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessTypeName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProcessTypeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.process.type_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessTypeName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProcessTypeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.process.type_name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProcessTypeName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProjectID.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.project.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectID.Include) + if mbc.ResourceAttributes.MongodbAtlasProjectID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.project.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectID.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProjectID.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.project.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectID.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProjectID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.project.id"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectID.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProjectName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.project.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectName.Include) + if mbc.ResourceAttributes.MongodbAtlasProjectName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.project.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProjectName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.project.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProjectName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.project.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProjectName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasProviderName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.provider.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProviderName.Include) + if mbc.ResourceAttributes.MongodbAtlasProviderName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.provider.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProviderName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasProviderName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.provider.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProviderName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasProviderName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.provider.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasProviderName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasRegionName.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.region.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasRegionName.Include) + if mbc.ResourceAttributes.MongodbAtlasRegionName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.region.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasRegionName.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasRegionName.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.region.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasRegionName.Exclude) + if mbc.ResourceAttributes.MongodbAtlasRegionName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.region.name"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasRegionName.MetricsExclude) } - if mbc.ResourceAttributes.MongodbAtlasUserAlias.Include != nil { - mb.resourceAttributeIncludeFilter["mongodb_atlas.user.alias"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasUserAlias.Include) + if mbc.ResourceAttributes.MongodbAtlasUserAlias.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mongodb_atlas.user.alias"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasUserAlias.MetricsInclude) } - if mbc.ResourceAttributes.MongodbAtlasUserAlias.Exclude != nil { - mb.resourceAttributeExcludeFilter["mongodb_atlas.user.alias"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasUserAlias.Exclude) + if mbc.ResourceAttributes.MongodbAtlasUserAlias.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mongodb_atlas.user.alias"] = filter.CreateFilter(mbc.ResourceAttributes.MongodbAtlasUserAlias.MetricsExclude) } for _, op := range options { diff --git a/receiver/mongodbatlasreceiver/internal/metadata/testdata/config.yaml b/receiver/mongodbatlasreceiver/internal/metadata/testdata/config.yaml index aba41774abfc..cba17b3284e7 100644 --- a/receiver/mongodbatlasreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/mongodbatlasreceiver/internal/metadata/testdata/config.yaml @@ -309,107 +309,107 @@ filter_set_include: resource_attributes: mongodb_atlas.cluster.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.db.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.disk.partition: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.host.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.org_name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.process.id: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.process.port: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.process.type_name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.project.id: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.project.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.provider.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.region.name: enabled: true - include: + metrics_include: - regexp: ".*" mongodb_atlas.user.alias: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: mongodb_atlas.cluster.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.cluster.name-val" mongodb_atlas.db.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.db.name-val" mongodb_atlas.disk.partition: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.disk.partition-val" mongodb_atlas.host.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.host.name-val" mongodb_atlas.org_name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.org_name-val" mongodb_atlas.process.id: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.process.id-val" mongodb_atlas.process.port: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.process.port-val" mongodb_atlas.process.type_name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.process.type_name-val" mongodb_atlas.project.id: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.project.id-val" mongodb_atlas.project.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.project.name-val" mongodb_atlas.provider.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.provider.name-val" mongodb_atlas.region.name: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.region.name-val" mongodb_atlas.user.alias: enabled: true - exclude: + metrics_exclude: - strict: "mongodb_atlas.user.alias-val" diff --git a/receiver/mongodbreceiver/internal/metadata/generated_config.go b/receiver/mongodbreceiver/internal/metadata/generated_config.go index bc071033ae1b..e3424ba14d83 100644 --- a/receiver/mongodbreceiver/internal/metadata/generated_config.go +++ b/receiver/mongodbreceiver/internal/metadata/generated_config.go @@ -157,9 +157,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/mongodbreceiver/internal/metadata/generated_metrics.go b/receiver/mongodbreceiver/internal/metadata/generated_metrics.go index 1a9b164721bf..714286ae6018 100644 --- a/receiver/mongodbreceiver/internal/metadata/generated_metrics.go +++ b/receiver/mongodbreceiver/internal/metadata/generated_metrics.go @@ -1897,11 +1897,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.Database.Include != nil { - mb.resourceAttributeIncludeFilter["database"] = filter.CreateFilter(mbc.ResourceAttributes.Database.Include) + if mbc.ResourceAttributes.Database.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["database"] = filter.CreateFilter(mbc.ResourceAttributes.Database.MetricsInclude) } - if mbc.ResourceAttributes.Database.Exclude != nil { - mb.resourceAttributeExcludeFilter["database"] = filter.CreateFilter(mbc.ResourceAttributes.Database.Exclude) + if mbc.ResourceAttributes.Database.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["database"] = filter.CreateFilter(mbc.ResourceAttributes.Database.MetricsExclude) } for _, op := range options { diff --git a/receiver/mongodbreceiver/internal/metadata/testdata/config.yaml b/receiver/mongodbreceiver/internal/metadata/testdata/config.yaml index 94213d1d0983..076b14c17be0 100644 --- a/receiver/mongodbreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/mongodbreceiver/internal/metadata/testdata/config.yaml @@ -133,11 +133,11 @@ filter_set_include: resource_attributes: database: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: database: enabled: true - exclude: + metrics_exclude: - strict: "database-val" diff --git a/receiver/mysqlreceiver/internal/metadata/generated_config.go b/receiver/mysqlreceiver/internal/metadata/generated_config.go index 395d5cdd24f2..c387eb0fe44d 100644 --- a/receiver/mysqlreceiver/internal/metadata/generated_config.go +++ b/receiver/mysqlreceiver/internal/metadata/generated_config.go @@ -209,9 +209,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/mysqlreceiver/internal/metadata/generated_metrics.go b/receiver/mysqlreceiver/internal/metadata/generated_metrics.go index 75b9c1be4558..4246d2ced03f 100644 --- a/receiver/mysqlreceiver/internal/metadata/generated_metrics.go +++ b/receiver/mysqlreceiver/internal/metadata/generated_metrics.go @@ -3385,11 +3385,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.MysqlInstanceEndpoint.Include != nil { - mb.resourceAttributeIncludeFilter["mysql.instance.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.MysqlInstanceEndpoint.Include) + if mbc.ResourceAttributes.MysqlInstanceEndpoint.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["mysql.instance.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.MysqlInstanceEndpoint.MetricsInclude) } - if mbc.ResourceAttributes.MysqlInstanceEndpoint.Exclude != nil { - mb.resourceAttributeExcludeFilter["mysql.instance.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.MysqlInstanceEndpoint.Exclude) + if mbc.ResourceAttributes.MysqlInstanceEndpoint.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["mysql.instance.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.MysqlInstanceEndpoint.MetricsExclude) } for _, op := range options { diff --git a/receiver/mysqlreceiver/internal/metadata/testdata/config.yaml b/receiver/mysqlreceiver/internal/metadata/testdata/config.yaml index b90fcf504616..92c7b4fe184e 100644 --- a/receiver/mysqlreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/mysqlreceiver/internal/metadata/testdata/config.yaml @@ -185,11 +185,11 @@ filter_set_include: resource_attributes: mysql.instance.endpoint: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: mysql.instance.endpoint: enabled: true - exclude: + metrics_exclude: - strict: "mysql.instance.endpoint-val" diff --git a/receiver/nsxtreceiver/internal/metadata/generated_config.go b/receiver/nsxtreceiver/internal/metadata/generated_config.go index a6f386820a66..b7b4e2a3dc57 100644 --- a/receiver/nsxtreceiver/internal/metadata/generated_config.go +++ b/receiver/nsxtreceiver/internal/metadata/generated_config.go @@ -65,9 +65,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/nsxtreceiver/internal/metadata/generated_metrics.go b/receiver/nsxtreceiver/internal/metadata/generated_metrics.go index 587449d45c21..1b3845de87f3 100644 --- a/receiver/nsxtreceiver/internal/metadata/generated_metrics.go +++ b/receiver/nsxtreceiver/internal/metadata/generated_metrics.go @@ -527,29 +527,29 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.DeviceID.Include != nil { - mb.resourceAttributeIncludeFilter["device.id"] = filter.CreateFilter(mbc.ResourceAttributes.DeviceID.Include) + if mbc.ResourceAttributes.DeviceID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["device.id"] = filter.CreateFilter(mbc.ResourceAttributes.DeviceID.MetricsInclude) } - if mbc.ResourceAttributes.DeviceID.Exclude != nil { - mb.resourceAttributeExcludeFilter["device.id"] = filter.CreateFilter(mbc.ResourceAttributes.DeviceID.Exclude) + if mbc.ResourceAttributes.DeviceID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["device.id"] = filter.CreateFilter(mbc.ResourceAttributes.DeviceID.MetricsExclude) } - if mbc.ResourceAttributes.NsxtNodeID.Include != nil { - mb.resourceAttributeIncludeFilter["nsxt.node.id"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeID.Include) + if mbc.ResourceAttributes.NsxtNodeID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["nsxt.node.id"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeID.MetricsInclude) } - if mbc.ResourceAttributes.NsxtNodeID.Exclude != nil { - mb.resourceAttributeExcludeFilter["nsxt.node.id"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeID.Exclude) + if mbc.ResourceAttributes.NsxtNodeID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["nsxt.node.id"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeID.MetricsExclude) } - if mbc.ResourceAttributes.NsxtNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["nsxt.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeName.Include) + if mbc.ResourceAttributes.NsxtNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["nsxt.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeName.MetricsInclude) } - if mbc.ResourceAttributes.NsxtNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["nsxt.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeName.Exclude) + if mbc.ResourceAttributes.NsxtNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["nsxt.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeName.MetricsExclude) } - if mbc.ResourceAttributes.NsxtNodeType.Include != nil { - mb.resourceAttributeIncludeFilter["nsxt.node.type"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeType.Include) + if mbc.ResourceAttributes.NsxtNodeType.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["nsxt.node.type"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeType.MetricsInclude) } - if mbc.ResourceAttributes.NsxtNodeType.Exclude != nil { - mb.resourceAttributeExcludeFilter["nsxt.node.type"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeType.Exclude) + if mbc.ResourceAttributes.NsxtNodeType.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["nsxt.node.type"] = filter.CreateFilter(mbc.ResourceAttributes.NsxtNodeType.MetricsExclude) } for _, op := range options { diff --git a/receiver/nsxtreceiver/internal/metadata/testdata/config.yaml b/receiver/nsxtreceiver/internal/metadata/testdata/config.yaml index 407525fc359e..aa3559eae04d 100644 --- a/receiver/nsxtreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/nsxtreceiver/internal/metadata/testdata/config.yaml @@ -53,35 +53,35 @@ filter_set_include: resource_attributes: device.id: enabled: true - include: + metrics_include: - regexp: ".*" nsxt.node.id: enabled: true - include: + metrics_include: - regexp: ".*" nsxt.node.name: enabled: true - include: + metrics_include: - regexp: ".*" nsxt.node.type: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: device.id: enabled: true - exclude: + metrics_exclude: - strict: "device.id-val" nsxt.node.id: enabled: true - exclude: + metrics_exclude: - strict: "nsxt.node.id-val" nsxt.node.name: enabled: true - exclude: + metrics_exclude: - strict: "nsxt.node.name-val" nsxt.node.type: enabled: true - exclude: + metrics_exclude: - strict: "nsxt.node.type-val" diff --git a/receiver/oracledbreceiver/internal/metadata/generated_config.go b/receiver/oracledbreceiver/internal/metadata/generated_config.go index 2f31f2f8cd14..4324eff94431 100644 --- a/receiver/oracledbreceiver/internal/metadata/generated_config.go +++ b/receiver/oracledbreceiver/internal/metadata/generated_config.go @@ -145,9 +145,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/oracledbreceiver/internal/metadata/generated_metrics.go b/receiver/oracledbreceiver/internal/metadata/generated_metrics.go index e526b4c7bc7a..2b6cc8dd7147 100644 --- a/receiver/oracledbreceiver/internal/metadata/generated_metrics.go +++ b/receiver/oracledbreceiver/internal/metadata/generated_metrics.go @@ -1455,11 +1455,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.OracledbInstanceName.Include != nil { - mb.resourceAttributeIncludeFilter["oracledb.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.OracledbInstanceName.Include) + if mbc.ResourceAttributes.OracledbInstanceName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["oracledb.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.OracledbInstanceName.MetricsInclude) } - if mbc.ResourceAttributes.OracledbInstanceName.Exclude != nil { - mb.resourceAttributeExcludeFilter["oracledb.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.OracledbInstanceName.Exclude) + if mbc.ResourceAttributes.OracledbInstanceName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["oracledb.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.OracledbInstanceName.MetricsExclude) } for _, op := range options { diff --git a/receiver/oracledbreceiver/internal/metadata/testdata/config.yaml b/receiver/oracledbreceiver/internal/metadata/testdata/config.yaml index 64a3189e38af..2f44bf2234aa 100644 --- a/receiver/oracledbreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/oracledbreceiver/internal/metadata/testdata/config.yaml @@ -121,11 +121,11 @@ filter_set_include: resource_attributes: oracledb.instance.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: oracledb.instance.name: enabled: true - exclude: + metrics_exclude: - strict: "oracledb.instance.name-val" diff --git a/receiver/podmanreceiver/internal/metadata/generated_config.go b/receiver/podmanreceiver/internal/metadata/generated_config.go index 54628e5a4e53..1a85a217994a 100644 --- a/receiver/podmanreceiver/internal/metadata/generated_config.go +++ b/receiver/podmanreceiver/internal/metadata/generated_config.go @@ -81,9 +81,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/podmanreceiver/internal/metadata/generated_metrics.go b/receiver/podmanreceiver/internal/metadata/generated_metrics.go index 40d2162b32c8..d465b00f0a0d 100644 --- a/receiver/podmanreceiver/internal/metadata/generated_metrics.go +++ b/receiver/podmanreceiver/internal/metadata/generated_metrics.go @@ -624,29 +624,29 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ContainerID.Include != nil { - mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Include) + if mbc.ResourceAttributes.ContainerID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsInclude) } - if mbc.ResourceAttributes.ContainerID.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.Exclude) + if mbc.ResourceAttributes.ContainerID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.id"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerID.MetricsExclude) } - if mbc.ResourceAttributes.ContainerImageName.Include != nil { - mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Include) + if mbc.ResourceAttributes.ContainerImageName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsInclude) } - if mbc.ResourceAttributes.ContainerImageName.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.Exclude) + if mbc.ResourceAttributes.ContainerImageName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.image.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerImageName.MetricsExclude) } - if mbc.ResourceAttributes.ContainerName.Include != nil { - mb.resourceAttributeIncludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.Include) + if mbc.ResourceAttributes.ContainerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.MetricsInclude) } - if mbc.ResourceAttributes.ContainerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.Exclude) + if mbc.ResourceAttributes.ContainerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.name"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerName.MetricsExclude) } - if mbc.ResourceAttributes.ContainerRuntime.Include != nil { - mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Include) + if mbc.ResourceAttributes.ContainerRuntime.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsInclude) } - if mbc.ResourceAttributes.ContainerRuntime.Exclude != nil { - mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.Exclude) + if mbc.ResourceAttributes.ContainerRuntime.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["container.runtime"] = filter.CreateFilter(mbc.ResourceAttributes.ContainerRuntime.MetricsExclude) } for _, op := range options { diff --git a/receiver/podmanreceiver/internal/metadata/testdata/config.yaml b/receiver/podmanreceiver/internal/metadata/testdata/config.yaml index 642d7e422a56..000f9140bf7f 100644 --- a/receiver/podmanreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/podmanreceiver/internal/metadata/testdata/config.yaml @@ -69,35 +69,35 @@ filter_set_include: resource_attributes: container.id: enabled: true - include: + metrics_include: - regexp: ".*" container.image.name: enabled: true - include: + metrics_include: - regexp: ".*" container.name: enabled: true - include: + metrics_include: - regexp: ".*" container.runtime: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: container.id: enabled: true - exclude: + metrics_exclude: - strict: "container.id-val" container.image.name: enabled: true - exclude: + metrics_exclude: - strict: "container.image.name-val" container.name: enabled: true - exclude: + metrics_exclude: - strict: "container.name-val" container.runtime: enabled: true - exclude: + metrics_exclude: - strict: "container.runtime-val" diff --git a/receiver/postgresqlreceiver/internal/metadata/generated_config.go b/receiver/postgresqlreceiver/internal/metadata/generated_config.go index 72277bf6da7b..a0a53f803403 100644 --- a/receiver/postgresqlreceiver/internal/metadata/generated_config.go +++ b/receiver/postgresqlreceiver/internal/metadata/generated_config.go @@ -145,9 +145,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/postgresqlreceiver/internal/metadata/generated_metrics.go b/receiver/postgresqlreceiver/internal/metadata/generated_metrics.go index ac4152310d2f..b5c5b93d8e84 100644 --- a/receiver/postgresqlreceiver/internal/metadata/generated_metrics.go +++ b/receiver/postgresqlreceiver/internal/metadata/generated_metrics.go @@ -1710,29 +1710,29 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.PostgresqlDatabaseName.Include != nil { - mb.resourceAttributeIncludeFilter["postgresql.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlDatabaseName.Include) + if mbc.ResourceAttributes.PostgresqlDatabaseName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["postgresql.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlDatabaseName.MetricsInclude) } - if mbc.ResourceAttributes.PostgresqlDatabaseName.Exclude != nil { - mb.resourceAttributeExcludeFilter["postgresql.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlDatabaseName.Exclude) + if mbc.ResourceAttributes.PostgresqlDatabaseName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["postgresql.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlDatabaseName.MetricsExclude) } - if mbc.ResourceAttributes.PostgresqlIndexName.Include != nil { - mb.resourceAttributeIncludeFilter["postgresql.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlIndexName.Include) + if mbc.ResourceAttributes.PostgresqlIndexName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["postgresql.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlIndexName.MetricsInclude) } - if mbc.ResourceAttributes.PostgresqlIndexName.Exclude != nil { - mb.resourceAttributeExcludeFilter["postgresql.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlIndexName.Exclude) + if mbc.ResourceAttributes.PostgresqlIndexName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["postgresql.index.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlIndexName.MetricsExclude) } - if mbc.ResourceAttributes.PostgresqlSchemaName.Include != nil { - mb.resourceAttributeIncludeFilter["postgresql.schema.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlSchemaName.Include) + if mbc.ResourceAttributes.PostgresqlSchemaName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["postgresql.schema.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlSchemaName.MetricsInclude) } - if mbc.ResourceAttributes.PostgresqlSchemaName.Exclude != nil { - mb.resourceAttributeExcludeFilter["postgresql.schema.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlSchemaName.Exclude) + if mbc.ResourceAttributes.PostgresqlSchemaName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["postgresql.schema.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlSchemaName.MetricsExclude) } - if mbc.ResourceAttributes.PostgresqlTableName.Include != nil { - mb.resourceAttributeIncludeFilter["postgresql.table.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlTableName.Include) + if mbc.ResourceAttributes.PostgresqlTableName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["postgresql.table.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlTableName.MetricsInclude) } - if mbc.ResourceAttributes.PostgresqlTableName.Exclude != nil { - mb.resourceAttributeExcludeFilter["postgresql.table.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlTableName.Exclude) + if mbc.ResourceAttributes.PostgresqlTableName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["postgresql.table.name"] = filter.CreateFilter(mbc.ResourceAttributes.PostgresqlTableName.MetricsExclude) } for _, op := range options { diff --git a/receiver/postgresqlreceiver/internal/metadata/testdata/config.yaml b/receiver/postgresqlreceiver/internal/metadata/testdata/config.yaml index 952716cb378f..8cf4613c3849 100644 --- a/receiver/postgresqlreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/postgresqlreceiver/internal/metadata/testdata/config.yaml @@ -133,35 +133,35 @@ filter_set_include: resource_attributes: postgresql.database.name: enabled: true - include: + metrics_include: - regexp: ".*" postgresql.index.name: enabled: true - include: + metrics_include: - regexp: ".*" postgresql.schema.name: enabled: true - include: + metrics_include: - regexp: ".*" postgresql.table.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: postgresql.database.name: enabled: true - exclude: + metrics_exclude: - strict: "postgresql.database.name-val" postgresql.index.name: enabled: true - exclude: + metrics_exclude: - strict: "postgresql.index.name-val" postgresql.schema.name: enabled: true - exclude: + metrics_exclude: - strict: "postgresql.schema.name-val" postgresql.table.name: enabled: true - exclude: + metrics_exclude: - strict: "postgresql.table.name-val" diff --git a/receiver/rabbitmqreceiver/internal/metadata/generated_config.go b/receiver/rabbitmqreceiver/internal/metadata/generated_config.go index 806a1ca67405..5857e880ebf0 100644 --- a/receiver/rabbitmqreceiver/internal/metadata/generated_config.go +++ b/receiver/rabbitmqreceiver/internal/metadata/generated_config.go @@ -61,9 +61,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/rabbitmqreceiver/internal/metadata/generated_metrics.go b/receiver/rabbitmqreceiver/internal/metadata/generated_metrics.go index e30d5fff4de9..e4605496d041 100644 --- a/receiver/rabbitmqreceiver/internal/metadata/generated_metrics.go +++ b/receiver/rabbitmqreceiver/internal/metadata/generated_metrics.go @@ -389,23 +389,23 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.RabbitmqNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["rabbitmq.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqNodeName.Include) + if mbc.ResourceAttributes.RabbitmqNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["rabbitmq.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqNodeName.MetricsInclude) } - if mbc.ResourceAttributes.RabbitmqNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["rabbitmq.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqNodeName.Exclude) + if mbc.ResourceAttributes.RabbitmqNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["rabbitmq.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqNodeName.MetricsExclude) } - if mbc.ResourceAttributes.RabbitmqQueueName.Include != nil { - mb.resourceAttributeIncludeFilter["rabbitmq.queue.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqQueueName.Include) + if mbc.ResourceAttributes.RabbitmqQueueName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["rabbitmq.queue.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqQueueName.MetricsInclude) } - if mbc.ResourceAttributes.RabbitmqQueueName.Exclude != nil { - mb.resourceAttributeExcludeFilter["rabbitmq.queue.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqQueueName.Exclude) + if mbc.ResourceAttributes.RabbitmqQueueName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["rabbitmq.queue.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqQueueName.MetricsExclude) } - if mbc.ResourceAttributes.RabbitmqVhostName.Include != nil { - mb.resourceAttributeIncludeFilter["rabbitmq.vhost.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqVhostName.Include) + if mbc.ResourceAttributes.RabbitmqVhostName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["rabbitmq.vhost.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqVhostName.MetricsInclude) } - if mbc.ResourceAttributes.RabbitmqVhostName.Exclude != nil { - mb.resourceAttributeExcludeFilter["rabbitmq.vhost.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqVhostName.Exclude) + if mbc.ResourceAttributes.RabbitmqVhostName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["rabbitmq.vhost.name"] = filter.CreateFilter(mbc.ResourceAttributes.RabbitmqVhostName.MetricsExclude) } for _, op := range options { diff --git a/receiver/rabbitmqreceiver/internal/metadata/testdata/config.yaml b/receiver/rabbitmqreceiver/internal/metadata/testdata/config.yaml index e185f9bbb9bb..0ed13b5f035e 100644 --- a/receiver/rabbitmqreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/rabbitmqreceiver/internal/metadata/testdata/config.yaml @@ -45,27 +45,27 @@ filter_set_include: resource_attributes: rabbitmq.node.name: enabled: true - include: + metrics_include: - regexp: ".*" rabbitmq.queue.name: enabled: true - include: + metrics_include: - regexp: ".*" rabbitmq.vhost.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: rabbitmq.node.name: enabled: true - exclude: + metrics_exclude: - strict: "rabbitmq.node.name-val" rabbitmq.queue.name: enabled: true - exclude: + metrics_exclude: - strict: "rabbitmq.queue.name-val" rabbitmq.vhost.name: enabled: true - exclude: + metrics_exclude: - strict: "rabbitmq.vhost.name-val" diff --git a/receiver/redisreceiver/internal/metadata/generated_config.go b/receiver/redisreceiver/internal/metadata/generated_config.go index 397511994cef..1eb628b7220d 100644 --- a/receiver/redisreceiver/internal/metadata/generated_config.go +++ b/receiver/redisreceiver/internal/metadata/generated_config.go @@ -177,9 +177,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/redisreceiver/internal/metadata/generated_metrics.go b/receiver/redisreceiver/internal/metadata/generated_metrics.go index 654cacc01878..f376d8ccd300 100644 --- a/receiver/redisreceiver/internal/metadata/generated_metrics.go +++ b/receiver/redisreceiver/internal/metadata/generated_metrics.go @@ -1979,23 +1979,23 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.RedisVersion.Include != nil { - mb.resourceAttributeIncludeFilter["redis.version"] = filter.CreateFilter(mbc.ResourceAttributes.RedisVersion.Include) + if mbc.ResourceAttributes.RedisVersion.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["redis.version"] = filter.CreateFilter(mbc.ResourceAttributes.RedisVersion.MetricsInclude) } - if mbc.ResourceAttributes.RedisVersion.Exclude != nil { - mb.resourceAttributeExcludeFilter["redis.version"] = filter.CreateFilter(mbc.ResourceAttributes.RedisVersion.Exclude) + if mbc.ResourceAttributes.RedisVersion.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["redis.version"] = filter.CreateFilter(mbc.ResourceAttributes.RedisVersion.MetricsExclude) } - if mbc.ResourceAttributes.ServerAddress.Include != nil { - mb.resourceAttributeIncludeFilter["server.address"] = filter.CreateFilter(mbc.ResourceAttributes.ServerAddress.Include) + if mbc.ResourceAttributes.ServerAddress.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["server.address"] = filter.CreateFilter(mbc.ResourceAttributes.ServerAddress.MetricsInclude) } - if mbc.ResourceAttributes.ServerAddress.Exclude != nil { - mb.resourceAttributeExcludeFilter["server.address"] = filter.CreateFilter(mbc.ResourceAttributes.ServerAddress.Exclude) + if mbc.ResourceAttributes.ServerAddress.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["server.address"] = filter.CreateFilter(mbc.ResourceAttributes.ServerAddress.MetricsExclude) } - if mbc.ResourceAttributes.ServerPort.Include != nil { - mb.resourceAttributeIncludeFilter["server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ServerPort.Include) + if mbc.ResourceAttributes.ServerPort.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ServerPort.MetricsInclude) } - if mbc.ResourceAttributes.ServerPort.Exclude != nil { - mb.resourceAttributeExcludeFilter["server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ServerPort.Exclude) + if mbc.ResourceAttributes.ServerPort.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["server.port"] = filter.CreateFilter(mbc.ResourceAttributes.ServerPort.MetricsExclude) } for _, op := range options { diff --git a/receiver/redisreceiver/internal/metadata/testdata/config.yaml b/receiver/redisreceiver/internal/metadata/testdata/config.yaml index 9b02e550f19b..be12a9f4cdf8 100644 --- a/receiver/redisreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/redisreceiver/internal/metadata/testdata/config.yaml @@ -161,27 +161,27 @@ filter_set_include: resource_attributes: redis.version: enabled: true - include: + metrics_include: - regexp: ".*" server.address: enabled: true - include: + metrics_include: - regexp: ".*" server.port: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: redis.version: enabled: true - exclude: + metrics_exclude: - strict: "redis.version-val" server.address: enabled: true - exclude: + metrics_exclude: - strict: "server.address-val" server.port: enabled: true - exclude: + metrics_exclude: - strict: "server.port-val" diff --git a/receiver/riakreceiver/internal/metadata/generated_config.go b/receiver/riakreceiver/internal/metadata/generated_config.go index e1383b23b1e3..9d9582e968e4 100644 --- a/receiver/riakreceiver/internal/metadata/generated_config.go +++ b/receiver/riakreceiver/internal/metadata/generated_config.go @@ -61,9 +61,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/riakreceiver/internal/metadata/generated_metrics.go b/receiver/riakreceiver/internal/metadata/generated_metrics.go index da1dc0e9e00c..9c8ae679b4e3 100644 --- a/receiver/riakreceiver/internal/metadata/generated_metrics.go +++ b/receiver/riakreceiver/internal/metadata/generated_metrics.go @@ -423,11 +423,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.RiakNodeName.Include != nil { - mb.resourceAttributeIncludeFilter["riak.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RiakNodeName.Include) + if mbc.ResourceAttributes.RiakNodeName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["riak.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RiakNodeName.MetricsInclude) } - if mbc.ResourceAttributes.RiakNodeName.Exclude != nil { - mb.resourceAttributeExcludeFilter["riak.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RiakNodeName.Exclude) + if mbc.ResourceAttributes.RiakNodeName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["riak.node.name"] = filter.CreateFilter(mbc.ResourceAttributes.RiakNodeName.MetricsExclude) } for _, op := range options { diff --git a/receiver/riakreceiver/internal/metadata/testdata/config.yaml b/receiver/riakreceiver/internal/metadata/testdata/config.yaml index bd67510be16a..c9667ff92479 100644 --- a/receiver/riakreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/riakreceiver/internal/metadata/testdata/config.yaml @@ -37,11 +37,11 @@ filter_set_include: resource_attributes: riak.node.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: riak.node.name: enabled: true - exclude: + metrics_exclude: - strict: "riak.node.name-val" diff --git a/receiver/saphanareceiver/internal/metadata/generated_config.go b/receiver/saphanareceiver/internal/metadata/generated_config.go index 40e5172a58be..99552c2e92b0 100644 --- a/receiver/saphanareceiver/internal/metadata/generated_config.go +++ b/receiver/saphanareceiver/internal/metadata/generated_config.go @@ -217,9 +217,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/saphanareceiver/internal/metadata/generated_metrics.go b/receiver/saphanareceiver/internal/metadata/generated_metrics.go index beebc69e2946..254137a4f83a 100644 --- a/receiver/saphanareceiver/internal/metadata/generated_metrics.go +++ b/receiver/saphanareceiver/internal/metadata/generated_metrics.go @@ -3040,17 +3040,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.DbSystem.Include != nil { - mb.resourceAttributeIncludeFilter["db.system"] = filter.CreateFilter(mbc.ResourceAttributes.DbSystem.Include) + if mbc.ResourceAttributes.DbSystem.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["db.system"] = filter.CreateFilter(mbc.ResourceAttributes.DbSystem.MetricsInclude) } - if mbc.ResourceAttributes.DbSystem.Exclude != nil { - mb.resourceAttributeExcludeFilter["db.system"] = filter.CreateFilter(mbc.ResourceAttributes.DbSystem.Exclude) + if mbc.ResourceAttributes.DbSystem.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["db.system"] = filter.CreateFilter(mbc.ResourceAttributes.DbSystem.MetricsExclude) } - if mbc.ResourceAttributes.SaphanaHost.Include != nil { - mb.resourceAttributeIncludeFilter["saphana.host"] = filter.CreateFilter(mbc.ResourceAttributes.SaphanaHost.Include) + if mbc.ResourceAttributes.SaphanaHost.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["saphana.host"] = filter.CreateFilter(mbc.ResourceAttributes.SaphanaHost.MetricsInclude) } - if mbc.ResourceAttributes.SaphanaHost.Exclude != nil { - mb.resourceAttributeExcludeFilter["saphana.host"] = filter.CreateFilter(mbc.ResourceAttributes.SaphanaHost.Exclude) + if mbc.ResourceAttributes.SaphanaHost.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["saphana.host"] = filter.CreateFilter(mbc.ResourceAttributes.SaphanaHost.MetricsExclude) } for _, op := range options { diff --git a/receiver/saphanareceiver/internal/metadata/testdata/config.yaml b/receiver/saphanareceiver/internal/metadata/testdata/config.yaml index 11188dd141b0..4a17240bad85 100644 --- a/receiver/saphanareceiver/internal/metadata/testdata/config.yaml +++ b/receiver/saphanareceiver/internal/metadata/testdata/config.yaml @@ -197,19 +197,19 @@ filter_set_include: resource_attributes: db.system: enabled: true - include: + metrics_include: - regexp: ".*" saphana.host: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: db.system: enabled: true - exclude: + metrics_exclude: - strict: "db.system-val" saphana.host: enabled: true - exclude: + metrics_exclude: - strict: "saphana.host-val" diff --git a/receiver/snowflakereceiver/internal/metadata/generated_config.go b/receiver/snowflakereceiver/internal/metadata/generated_config.go index cb06651d2fe5..f8720e0d8582 100644 --- a/receiver/snowflakereceiver/internal/metadata/generated_config.go +++ b/receiver/snowflakereceiver/internal/metadata/generated_config.go @@ -177,9 +177,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/snowflakereceiver/internal/metadata/generated_metrics.go b/receiver/snowflakereceiver/internal/metadata/generated_metrics.go index 470a93954115..0ffd6e43674b 100644 --- a/receiver/snowflakereceiver/internal/metadata/generated_metrics.go +++ b/receiver/snowflakereceiver/internal/metadata/generated_metrics.go @@ -2008,11 +2008,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.SnowflakeAccountName.Include != nil { - mb.resourceAttributeIncludeFilter["snowflake.account.name"] = filter.CreateFilter(mbc.ResourceAttributes.SnowflakeAccountName.Include) + if mbc.ResourceAttributes.SnowflakeAccountName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["snowflake.account.name"] = filter.CreateFilter(mbc.ResourceAttributes.SnowflakeAccountName.MetricsInclude) } - if mbc.ResourceAttributes.SnowflakeAccountName.Exclude != nil { - mb.resourceAttributeExcludeFilter["snowflake.account.name"] = filter.CreateFilter(mbc.ResourceAttributes.SnowflakeAccountName.Exclude) + if mbc.ResourceAttributes.SnowflakeAccountName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["snowflake.account.name"] = filter.CreateFilter(mbc.ResourceAttributes.SnowflakeAccountName.MetricsExclude) } for _, op := range options { diff --git a/receiver/snowflakereceiver/internal/metadata/testdata/config.yaml b/receiver/snowflakereceiver/internal/metadata/testdata/config.yaml index 139560784eac..ca8d86db6562 100644 --- a/receiver/snowflakereceiver/internal/metadata/testdata/config.yaml +++ b/receiver/snowflakereceiver/internal/metadata/testdata/config.yaml @@ -153,11 +153,11 @@ filter_set_include: resource_attributes: snowflake.account.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: snowflake.account.name: enabled: true - exclude: + metrics_exclude: - strict: "snowflake.account.name-val" diff --git a/receiver/sqlserverreceiver/internal/metadata/generated_config.go b/receiver/sqlserverreceiver/internal/metadata/generated_config.go index 69c4c1b21f8b..b4b8ebe5e7ca 100644 --- a/receiver/sqlserverreceiver/internal/metadata/generated_config.go +++ b/receiver/sqlserverreceiver/internal/metadata/generated_config.go @@ -117,9 +117,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/sqlserverreceiver/internal/metadata/generated_metrics.go b/receiver/sqlserverreceiver/internal/metadata/generated_metrics.go index 630f2baa721b..1ec90d7e6178 100644 --- a/receiver/sqlserverreceiver/internal/metadata/generated_metrics.go +++ b/receiver/sqlserverreceiver/internal/metadata/generated_metrics.go @@ -1095,23 +1095,23 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.SqlserverComputerName.Include != nil { - mb.resourceAttributeIncludeFilter["sqlserver.computer.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverComputerName.Include) + if mbc.ResourceAttributes.SqlserverComputerName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["sqlserver.computer.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverComputerName.MetricsInclude) } - if mbc.ResourceAttributes.SqlserverComputerName.Exclude != nil { - mb.resourceAttributeExcludeFilter["sqlserver.computer.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverComputerName.Exclude) + if mbc.ResourceAttributes.SqlserverComputerName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["sqlserver.computer.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverComputerName.MetricsExclude) } - if mbc.ResourceAttributes.SqlserverDatabaseName.Include != nil { - mb.resourceAttributeIncludeFilter["sqlserver.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverDatabaseName.Include) + if mbc.ResourceAttributes.SqlserverDatabaseName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["sqlserver.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverDatabaseName.MetricsInclude) } - if mbc.ResourceAttributes.SqlserverDatabaseName.Exclude != nil { - mb.resourceAttributeExcludeFilter["sqlserver.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverDatabaseName.Exclude) + if mbc.ResourceAttributes.SqlserverDatabaseName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["sqlserver.database.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverDatabaseName.MetricsExclude) } - if mbc.ResourceAttributes.SqlserverInstanceName.Include != nil { - mb.resourceAttributeIncludeFilter["sqlserver.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverInstanceName.Include) + if mbc.ResourceAttributes.SqlserverInstanceName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["sqlserver.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverInstanceName.MetricsInclude) } - if mbc.ResourceAttributes.SqlserverInstanceName.Exclude != nil { - mb.resourceAttributeExcludeFilter["sqlserver.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverInstanceName.Exclude) + if mbc.ResourceAttributes.SqlserverInstanceName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["sqlserver.instance.name"] = filter.CreateFilter(mbc.ResourceAttributes.SqlserverInstanceName.MetricsExclude) } for _, op := range options { diff --git a/receiver/sqlserverreceiver/internal/metadata/testdata/config.yaml b/receiver/sqlserverreceiver/internal/metadata/testdata/config.yaml index 105050b11b42..41845c65e79a 100644 --- a/receiver/sqlserverreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/sqlserverreceiver/internal/metadata/testdata/config.yaml @@ -101,27 +101,27 @@ filter_set_include: resource_attributes: sqlserver.computer.name: enabled: true - include: + metrics_include: - regexp: ".*" sqlserver.database.name: enabled: true - include: + metrics_include: - regexp: ".*" sqlserver.instance.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: sqlserver.computer.name: enabled: true - exclude: + metrics_exclude: - strict: "sqlserver.computer.name-val" sqlserver.database.name: enabled: true - exclude: + metrics_exclude: - strict: "sqlserver.database.name-val" sqlserver.instance.name: enabled: true - exclude: + metrics_exclude: - strict: "sqlserver.instance.name-val" diff --git a/receiver/sshcheckreceiver/internal/metadata/generated_config.go b/receiver/sshcheckreceiver/internal/metadata/generated_config.go index 24ebc3153e2e..c72d94113020 100644 --- a/receiver/sshcheckreceiver/internal/metadata/generated_config.go +++ b/receiver/sshcheckreceiver/internal/metadata/generated_config.go @@ -61,9 +61,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/sshcheckreceiver/internal/metadata/generated_metrics.go b/receiver/sshcheckreceiver/internal/metadata/generated_metrics.go index b3b83a168f66..faa3f35add58 100644 --- a/receiver/sshcheckreceiver/internal/metadata/generated_metrics.go +++ b/receiver/sshcheckreceiver/internal/metadata/generated_metrics.go @@ -361,11 +361,11 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.SSHEndpoint.Include != nil { - mb.resourceAttributeIncludeFilter["ssh.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.SSHEndpoint.Include) + if mbc.ResourceAttributes.SSHEndpoint.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["ssh.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.SSHEndpoint.MetricsInclude) } - if mbc.ResourceAttributes.SSHEndpoint.Exclude != nil { - mb.resourceAttributeExcludeFilter["ssh.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.SSHEndpoint.Exclude) + if mbc.ResourceAttributes.SSHEndpoint.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["ssh.endpoint"] = filter.CreateFilter(mbc.ResourceAttributes.SSHEndpoint.MetricsExclude) } for _, op := range options { diff --git a/receiver/sshcheckreceiver/internal/metadata/testdata/config.yaml b/receiver/sshcheckreceiver/internal/metadata/testdata/config.yaml index 2c3f99626855..dd9b82c7804a 100644 --- a/receiver/sshcheckreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/sshcheckreceiver/internal/metadata/testdata/config.yaml @@ -37,11 +37,11 @@ filter_set_include: resource_attributes: ssh.endpoint: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: ssh.endpoint: enabled: true - exclude: + metrics_exclude: - strict: "ssh.endpoint-val" diff --git a/receiver/vcenterreceiver/internal/metadata/generated_config.go b/receiver/vcenterreceiver/internal/metadata/generated_config.go index 85ba0bfd78a7..3349b12a1455 100644 --- a/receiver/vcenterreceiver/internal/metadata/generated_config.go +++ b/receiver/vcenterreceiver/internal/metadata/generated_config.go @@ -193,9 +193,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/vcenterreceiver/internal/metadata/generated_metrics.go b/receiver/vcenterreceiver/internal/metadata/generated_metrics.go index 463cd9ccf7ec..2168546c0cab 100644 --- a/receiver/vcenterreceiver/internal/metadata/generated_metrics.go +++ b/receiver/vcenterreceiver/internal/metadata/generated_metrics.go @@ -2263,47 +2263,47 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.VcenterClusterName.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterClusterName.Include) + if mbc.ResourceAttributes.VcenterClusterName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterClusterName.MetricsInclude) } - if mbc.ResourceAttributes.VcenterClusterName.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterClusterName.Exclude) + if mbc.ResourceAttributes.VcenterClusterName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.cluster.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterClusterName.MetricsExclude) } - if mbc.ResourceAttributes.VcenterDatastoreName.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.datastore.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterDatastoreName.Include) + if mbc.ResourceAttributes.VcenterDatastoreName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.datastore.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterDatastoreName.MetricsInclude) } - if mbc.ResourceAttributes.VcenterDatastoreName.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.datastore.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterDatastoreName.Exclude) + if mbc.ResourceAttributes.VcenterDatastoreName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.datastore.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterDatastoreName.MetricsExclude) } - if mbc.ResourceAttributes.VcenterHostName.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterHostName.Include) + if mbc.ResourceAttributes.VcenterHostName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterHostName.MetricsInclude) } - if mbc.ResourceAttributes.VcenterHostName.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterHostName.Exclude) + if mbc.ResourceAttributes.VcenterHostName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.host.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterHostName.MetricsExclude) } - if mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.resource_pool.inventory_path"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.Include) + if mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.resource_pool.inventory_path"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.MetricsInclude) } - if mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.resource_pool.inventory_path"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.Exclude) + if mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.resource_pool.inventory_path"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolInventoryPath.MetricsExclude) } - if mbc.ResourceAttributes.VcenterResourcePoolName.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.resource_pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolName.Include) + if mbc.ResourceAttributes.VcenterResourcePoolName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.resource_pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolName.MetricsInclude) } - if mbc.ResourceAttributes.VcenterResourcePoolName.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.resource_pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolName.Exclude) + if mbc.ResourceAttributes.VcenterResourcePoolName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.resource_pool.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterResourcePoolName.MetricsExclude) } - if mbc.ResourceAttributes.VcenterVMID.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.vm.id"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMID.Include) + if mbc.ResourceAttributes.VcenterVMID.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.vm.id"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMID.MetricsInclude) } - if mbc.ResourceAttributes.VcenterVMID.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.vm.id"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMID.Exclude) + if mbc.ResourceAttributes.VcenterVMID.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.vm.id"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMID.MetricsExclude) } - if mbc.ResourceAttributes.VcenterVMName.Include != nil { - mb.resourceAttributeIncludeFilter["vcenter.vm.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMName.Include) + if mbc.ResourceAttributes.VcenterVMName.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["vcenter.vm.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMName.MetricsInclude) } - if mbc.ResourceAttributes.VcenterVMName.Exclude != nil { - mb.resourceAttributeExcludeFilter["vcenter.vm.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMName.Exclude) + if mbc.ResourceAttributes.VcenterVMName.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["vcenter.vm.name"] = filter.CreateFilter(mbc.ResourceAttributes.VcenterVMName.MetricsExclude) } for _, op := range options { diff --git a/receiver/vcenterreceiver/internal/metadata/testdata/config.yaml b/receiver/vcenterreceiver/internal/metadata/testdata/config.yaml index f59d1ce7f7c3..23388464d2cb 100644 --- a/receiver/vcenterreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/vcenterreceiver/internal/metadata/testdata/config.yaml @@ -193,59 +193,59 @@ filter_set_include: resource_attributes: vcenter.cluster.name: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.datastore.name: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.host.name: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.resource_pool.inventory_path: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.resource_pool.name: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.vm.id: enabled: true - include: + metrics_include: - regexp: ".*" vcenter.vm.name: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: vcenter.cluster.name: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.cluster.name-val" vcenter.datastore.name: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.datastore.name-val" vcenter.host.name: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.host.name-val" vcenter.resource_pool.inventory_path: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.resource_pool.inventory_path-val" vcenter.resource_pool.name: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.resource_pool.name-val" vcenter.vm.id: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.vm.id-val" vcenter.vm.name: enabled: true - exclude: + metrics_exclude: - strict: "vcenter.vm.name-val" diff --git a/receiver/zookeeperreceiver/internal/metadata/generated_config.go b/receiver/zookeeperreceiver/internal/metadata/generated_config.go index eb3ee345fc9a..3496a47bd655 100644 --- a/receiver/zookeeperreceiver/internal/metadata/generated_config.go +++ b/receiver/zookeeperreceiver/internal/metadata/generated_config.go @@ -101,9 +101,14 @@ func DefaultMetricsConfig() MetricsConfig { // ResourceAttributeConfig provides common config for a particular resource attribute. type ResourceAttributeConfig struct { - Enabled bool `mapstructure:"enabled"` - Include []filter.Config `mapstructure:"include"` - Exclude []filter.Config `mapstructure:"exclude"` + Enabled bool `mapstructure:"enabled"` + // Experimental: MetricsInclude defines a list of filters for attribute values. + // If the list is not empty, only metrics with matching resource attribute values will be emitted. + MetricsInclude []filter.Config `mapstructure:"metrics_include"` + // Experimental: MetricsExclude defines a list of filters for attribute values. + // If the list is not empty, metrics with matching resource attribute values will not be emitted. + // MetricsInclude has higher priority than MetricsExclude. + MetricsExclude []filter.Config `mapstructure:"metrics_exclude"` enabledSetByUser bool } diff --git a/receiver/zookeeperreceiver/internal/metadata/generated_metrics.go b/receiver/zookeeperreceiver/internal/metadata/generated_metrics.go index 3bfa1ba9449d..29c98c3abc08 100644 --- a/receiver/zookeeperreceiver/internal/metadata/generated_metrics.go +++ b/receiver/zookeeperreceiver/internal/metadata/generated_metrics.go @@ -937,17 +937,17 @@ func NewMetricsBuilder(mbc MetricsBuilderConfig, settings receiver.CreateSetting resourceAttributeIncludeFilter: make(map[string]filter.Filter), resourceAttributeExcludeFilter: make(map[string]filter.Filter), } - if mbc.ResourceAttributes.ServerState.Include != nil { - mb.resourceAttributeIncludeFilter["server.state"] = filter.CreateFilter(mbc.ResourceAttributes.ServerState.Include) + if mbc.ResourceAttributes.ServerState.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["server.state"] = filter.CreateFilter(mbc.ResourceAttributes.ServerState.MetricsInclude) } - if mbc.ResourceAttributes.ServerState.Exclude != nil { - mb.resourceAttributeExcludeFilter["server.state"] = filter.CreateFilter(mbc.ResourceAttributes.ServerState.Exclude) + if mbc.ResourceAttributes.ServerState.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["server.state"] = filter.CreateFilter(mbc.ResourceAttributes.ServerState.MetricsExclude) } - if mbc.ResourceAttributes.ZkVersion.Include != nil { - mb.resourceAttributeIncludeFilter["zk.version"] = filter.CreateFilter(mbc.ResourceAttributes.ZkVersion.Include) + if mbc.ResourceAttributes.ZkVersion.MetricsInclude != nil { + mb.resourceAttributeIncludeFilter["zk.version"] = filter.CreateFilter(mbc.ResourceAttributes.ZkVersion.MetricsInclude) } - if mbc.ResourceAttributes.ZkVersion.Exclude != nil { - mb.resourceAttributeExcludeFilter["zk.version"] = filter.CreateFilter(mbc.ResourceAttributes.ZkVersion.Exclude) + if mbc.ResourceAttributes.ZkVersion.MetricsExclude != nil { + mb.resourceAttributeExcludeFilter["zk.version"] = filter.CreateFilter(mbc.ResourceAttributes.ZkVersion.MetricsExclude) } for _, op := range options { diff --git a/receiver/zookeeperreceiver/internal/metadata/testdata/config.yaml b/receiver/zookeeperreceiver/internal/metadata/testdata/config.yaml index 5a232174c8b7..5e7c5dc566d8 100644 --- a/receiver/zookeeperreceiver/internal/metadata/testdata/config.yaml +++ b/receiver/zookeeperreceiver/internal/metadata/testdata/config.yaml @@ -81,19 +81,19 @@ filter_set_include: resource_attributes: server.state: enabled: true - include: + metrics_include: - regexp: ".*" zk.version: enabled: true - include: + metrics_include: - regexp: ".*" filter_set_exclude: resource_attributes: server.state: enabled: true - exclude: + metrics_exclude: - strict: "server.state-val" zk.version: enabled: true - exclude: + metrics_exclude: - strict: "zk.version-val"