Releases: signalfx/splunk-otel-collector
v0.117.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.117.0 and the opentelemetry-collector-contrib v0.117.0 releases where appropriate.
🛑 Breaking changes 🛑
- (Contrib)
cloudfoundryreceiver
: Introduce a feature gate enable copying envelope tags to the metrics as resource attributes instead of datapoint attributes. (#34824) - (Contrib)
pkg/ottl
: removed the ability to reference entire parent objects. (#36872)
Statements likeset(cache["resource"], resource)
in non-resource contexts will no longer work. - (Contrib)
routingconnector
: Change default value ofmatch_once
parameter totrue
. (#29882)
This field was deprecated in v0.116.0 and will be removed in v0.120.0. - (Core)
otelcol
: Remove warnings when 0.0.0.0 is used (#11713, #8510)
🚩 Deprecations 🚩
- (Contrib)
sapmexporter
: Deprecate SAPM exporter (#36028)
The SAPM exporter is being marked as deprecated. Please use theotlphttp
exporter with the configuration shown
below. Also update your pipeline configuration for Traces accordingly.exporters: otlphttp: traces_endpoint: "${SPLUNK_INGEST_URL}/v2/trace/otlp" headers: "X-SF-Token": "${SPLUNK_ACCESS_TOKEN}"
🚀 New components 🚀
- (Splunk) Add
metricsgeneration
processor (#5769)
💡 Enhancements 💡
- (Splunk) Add a new discovery bundle for Envoy proxy metrics (#5780)
- (Contrib)
k8sclusterreceiver
: Add additional attributes to node and pod entities (#35879)
Adds the following attributes to node and pod metadata/entities:k8s.pod.phase
: The phase of a Pod indicates where the Pod is in its lifecycle. E.g. 'Pending', 'Running'k8s.pod.status_reason
: A brief message indicating details about why the pod is in this state. E.g. 'Evicted'k8s.node.condition_*
: The condition of a node. e.g.k8s.node.condition_ready
. The value can betrue
,false
,unknown
.
- (Contrib)
receivercreator
: Add support for starting logs' collection based on provided k8s annotations' hints (#34427) - (Contrib)
ottl
: Add a new ottl trim function that trims leading and trailing characters from a string (default- whitespace). (#34100) - (Contrib)
sqlqueryreceiver
: Add instrumentation scope to SQL query receiver metrics and logs (#31028) - (Contrib)
statsdreceiver
: Add UDS support to statsdreceiver (#21385) - (Contrib)
tailsamplingprocessor
: Support hot sampling policy loading (#37014)
🧰 Bug fixes 🧰
- (Splunk) Fix deprecation warning for multiline config source calls (#5829)
- (Contrib)
receiver/azureeventhub
: Ensure that observed timestamp is set when unmarshaling logs. (#36861) - (Contrib)
internal/docker
: Fix image matching regular expression to properly match SHA256 strings. (#36239)
This affects thedocker_observer
extension. - (Contrib)
k8sobjectsreceiver
: ensure thek8s.namespace.name
attribute is set for objects retrieved using thewatch
mode (#36352) - (Contrib)
mongodbatlasreceiver
: Update the mongoDB Atlas receiver to use the Default HTTP Transport that supports default proxy configuration (#36412) - (Contrib)
mysqlreceiver
: Avoid recording a value for the MysqlBufferPoolPages metric when out-of-bounds. (#35495)
When using compressed tables, Innodb_buffer_pool_pages_misc may report an out-of-bounds value.
See https://bugs.mysql.com/bug.php?id=59550 for context. - (Contrib)
pkg/ottl
: fix handling of nested maps within slices in theflatten
function (#36162) - (Contrib)
mysqlreceiver
: Divide large values directly in SQL queries to avoid int overflows (#35495) - (Core)
internal/sharedcomponent
: Fixed bug where sharedcomponent would use too much memory remembering all the previously reported statuses (#11826)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.117.0
- digest:
sha256:c07c949d244685030ad8ccd96bc8137b3d229a81e9dafc27c4f2e349e42d3cbb
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.117.0
- digest:
sha256:5b3df3fe83340b7f469d37cecd9ecd92805e97b09e28810547ddddfbf651156c
v0.116.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.116.0 and the opentelemetry-collector-contrib v0.116.0 releases where appropriate.
🛑 Breaking changes 🛑
- (Contrib)
processor/tailsampling
: Reverts #33671, allowing for composite policies to specify inverted clauses in conjunction with other policies. This is a change bringing the previous state into place, breaking users who rely on what was introduced as part of #33671. (#34085)
🚀 New components 🚀
- (Splunk) Add
bearertokenauth
extension (#5727) - (Splunk) Add
snowflake
receiver (#5724) - (Splunk) Add
purefa
receiver (#5731) - (Splunk) Add
sum
connector (#5730 )
🚩 Deprecations 🚩
- (Contrib)
connector/routing
: Deprecatematch_once
parameter. (#29882) - (Contrib)
routingprocessor
: Deprecated in favor of the routing connector. (#36616) - (Contrib)
splunkhecexporter
: Addotel_attrs_to_hec_metadata/*
config fields to replacehec_metadata_to_otel_attrs/*
fields. (#35092)
otel_attrs_to_hec_metadata/*
config fields will replace thehec_metadata_to_otel_attrs/*
fields in a later release.
💡 Enhancements 💡
- (Contrib)
purefareceiver
: Implements support for scraping Pure Storage FlashArray with Purity version 6.6.11+ (#36251) - (Contrib)
azureeventhubreceiver
: support providing one or more time formats for timestamp parsing (#36650) - (Contrib)
fileexporter
: Add support for profiles signal. (#35978) - (Contrib)
pkg/ottl
: GetXML Converter now supports selecting text, CDATA, and attribute (value) content. (#36821) - (Contrib)
kafkaexporter, kafkareceiver
: Add a new mechanism "AWS_MSK_IAM_OAUTHBEARER" for kafka exporter and kafka receiver. This mechanism use the AWS MSK IAM SASL Signer for Go https://github.com/aws/aws-msk-iam-sasl-signer-go. (#19747) - (Contrib)
loadbalancingexporter
: Adds a an optional configuration to the k8s resolver which returns hostnames instead of IPs for headless services pointing at statefulsets (#18412) - (Contrib)
mongodbatlasreceiver
: Adds additional metrics to the MongoDB Atlas receiver (#36525)
Adds a number of new default disabled metrics to the MongoDB Atlas receiver. These metrics are:- mongodbatlas.disk.partition.queue.depth
- mongodbatlas.disk.partition.throughput
- mongodbatlas.process.cache.ratio
- (Contrib)
s3exporter
: Upgrading to adopt aws sdk v2 (#36699)
🧰 Bug fixes 🧰
- (Core)
exporterhelper
: Fix memory leak at exporter shutdown (#11401) - (Core)
sharedcomponent
: Remove race-condition and cleanup locking (#11819) - (Contrib)
receiver/prometheusreceiver
: Metric adjuster no longer assumes that all metrics from a scrape come from the same resource (#36477) - (Contrib)
k8sattributesprocessor
: Override extracted k8s attributes if original value has been empty (#36373) - (Contrib)
k8sattributesprocessor
: Log any errors encountered during kube client initialisation (#35879)
This addresses an issue where the collector, due to an error encountered during the kubernetes client initialisation,
was reporting an 'unavailable' status via the health check extension without any further information to be found in the logs. - (Contrib)
postgresqlreceiver
: Update the postgresqlreceiver to handle new table schema for the bgwriter metrics in pg17+ (#36784) - (Contrib)
jaegerreceiver
: Remove ineffectual warning from jaegerreceiver (#35894)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.116.0
- digest:
sha256:375ed345d09d7b6c984e002a70f5f8f9881ffd250ca10fb519ac506e8a229bf0
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.116.0
- digest:
sha256:3aa04423420c06868802c55c0a113a9e749500d377b821e2552cc5aad6f6075c
v0.115.0
🛑 Breaking changes 🛑
- (Splunk) Change default traces exporter to otlphttp exporter. (#5588).
See the upgrade guidelines on how to change existing configs to replace SAPM exporter. - (Core) Change all logged timestamps to ISO8601 (#10543).
This makes log timestamps human-readable (as opposed to epoch seconds in
scientific notation), but may break users trying to parse logged lines in the
old format. - (Contrib)
k8sattributesprocessor
: Move k8sattr.fieldExtractConfigRegex.disallow feature gate to Beta. (#25128)
Disable thek8sattr.fieldExtractConfigRegex.disallow
feature gate to get the old behavior.
🚀 New components 🚀
💡 Enhancements 💡
- (Splunk) Automatic Discovery:
- Switch bundled NGINX discovery to create OpenTelemetry NGINX receiver instead of the Smart Agent NGINX monitor (#5689)
- (Splunk) Expose internal metrics at default
localhost:8888
address instead of${SPLUNK_LISTEN_INTERFACE}:8888
(#5706)
This can be changed inservice::telemetry::metrics
section:This also removes a warning about deprecatedservice: telemetry: metrics: readers: - pull: exporter: prometheus: host: localhost port: 8888
service::telemetry::metrics::address
. - (Core)
exporterqueue
: Introduce a feature gate exporter.UsePullingBasedExporterQueueBatcher to use the new pulling model in exporter queue batching. (#8122, #10368)
If both queuing and batching is enabled for exporter, we now use a pulling model instead of a
pushing model. num_consumer in queue configuration is now used to specify the maximum number of
concurrent workers that are sending out the request. - (Core)
service
: Add support for ca certificates in telemetry metrics otlp grpc exporter (#11633)
Before this change the Certificate value in config was silently ignored. - (Contrib)
postgresqlreceiver
: Added new postgresql metrics to achieve parity with Telegraf (#36528) - (Contrib)
loadbalancingexporter
: Adding sending_queue, retry_on_failure and timeout settings to loadbalancing exporter configuration (#35378)
When switching to top-level sending_queue configuration - users should carefully review queue size
In some rare cases setting top-level queue size to n*queueSize might be not enough to prevent data loss - (Contrib)
routingconnector
: Add abiilty to route by 'datapoint' context (#36523) - (Contrib)
signalfxreceiver
: Follow receiver contract based on type of error (#5909)
Use 503 error code for retryable and 400 error code for not-retryable errors instead of responding with a 500 unconditionally.
🧰 Bug fixes 🧰
- (Core)
service
: ensure OTLP emitted logs respect severity (#11718) - (Core)
featuregate
: Fix an unfriendly display messageruntime error
when feature gate is used to display command line usage. (#11651) - (Contrib)
exporter/pulsarexporter
: Change configuration optionmap_connections_per_broker
, rename tomax_connections_per_broker
. (#36579) - (Contrib)
processor/k8sattribute
: fixes parsing of k8s image names to support images with tags and digests. (#36131) - (Contrib)
loadbalancingexporter
: The k8sresolver in loadbalancingexporter was triggering exporter churn in the way the change event was handled. (#35658) - (Contrib)
vcenterreceiver
: The existing code did not honor TLS settings beyond 'insecure'. All TLS client config should now be honored. (#36482)
🚩Deprecations 🚩
- (Splunk) Deprecate the collectd/genericjmx monitor. Please use the jmxreceiver instead. (#5539)
- (Splunk) Deprecate the collectd/activemq monitor. Please use the jmxreceiver with the activemq target system instead. (#5539)
- (Splunk) Deprecate the collectd/cassandra monitor. Please use the jmxreceiver with the cassandra target system instead. (#5539)
- (Splunk) Deprecate the collectd/hadoop monitor. Please use the jmxreceiver with the hadoop target system instead. (#5539)
- (Splunk) Deprecate the collectd/kafka monitor. Please use the jmxreceiver with the kafka target system instead. (#5539)
- (Splunk) Deprecate the collectd/kafka-consumer monitor. Please use the jmxreceiver with the kafka-consumer target system instead. (#5539)
- (Splunk) Deprecate the collectd/kafka-producer monitor. Please use the jmxreceiver with the kafka-producer target system instead. (#5539)
- (Splunk) Deprecate the collectd/solr monitor. Please use the jmxreceiver with the solr target system instead. (#5539)
- (Splunk) Deprecate the collectd/tomcat monitor. Please use the jmxreceiver with the tomcat target system instead. (#5539)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.115.0
- digest:
sha256:1f7f859a1ccccea22c1d1a32bb2f807b8368660b386851be13db02d706ea3b7c
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.115.0
- digest:
sha256:f03d72285f53bc14f88e71a3e323713b752dea5a0581eeddc285f44e74418215
v0.114.0
💡 Enhancements 💡
- (Contrib)
processor/k8sattributes
: Add support for profiles signal (#35983) - (Contrib)
receiver/k8scluster
: Add support for limiting observed resources to a specific namespace. (#9401)
This change allows to make use of this receiver withRoles
/RoleBindings
, as opposed to giving the collector cluster-wide read access. - (Contrib)
processor/resourcedetection
: Introduce support for Profiles signal type. (#35980) - (Contrib)
connector/routing
: Add ability to route by metric context (#36236) - (Contrib)
connector/routing
: Add ability to route by span context (#36276) - (Contrib)
processor/spanprocessor
: Add a new configuration option to keep the original span name when extracting attributes from the span name. (#36120) - (Contrib)
receiver/splunkenterprise
: Add new metrics for Splunk Enterprise dispatch artifacts caches (#36181)
🚩Deprecations 🚩
- (Splunk)
SPLUNK_TRACE_URL
environment variable is deprecated. It's replaced with${SPLUNK_INGEST_URL}/v2/trace
in the default configs. Default value forSPLUNK_TRACE_URL
is still set in the binary fromSPLUNK_REALM
or
SPLUNK_INGEST_URL
environment variables to not break existing configurations. However, it is recommended to
update the configurations to use${SPLUNK_INGEST_URL}/v2/trace
instead. (#5672).
🛑 Breaking changes 🛑
- (Splunk) Given that
SPLUNK_TRACE_URL
environment variable is deprecated and replaced with
${SPLUNK_INGEST_URL}/v2/trace
in the default configurations, the option to set the Trace URL has been removed from
all packaging and mass deployment solutions to an avoid confusion. (#5672).
🧰 Bug fixes 🧰
- (Splunk)
receiver/journald
: Upgrade journald client libraries in the Collector docker image by taking them from latest Debian image.
This fixes journald receiver on kubernetes nodes with recent versions of systemd (#5664). - (Core) scraperhelper: If the scraper shuts down, do not scrape first. (#11632)
When the scraper is shutting down, it currently will scrape at least once. With this change, upon receiving a shutdown order, the receiver's scraperhelper will exit immediately. - (Contrib)
pkg/stanza
: Ensure that time parsing happens before entry is sent to downstream operators (#36213) - (Contrib)
processor/k8sattributes
: Block when starting until the metadata have been synced, to fix that some data couldn't be associated with metadata when the agent was just started. (#32556) - (Contrib)
exporter/loadbalancing
: Shutdown exporters during collector shutdown. This fixes a memory leak. (#36024) - (Contrib)
pkg/ottl
: Respect thedepth
option when flattening slices usingflatten
(#36161)
Thedepth
option is also now required to be at least1
. - (Contrib)
pkg/stanza
: Synchronous handling of entries passed from the log emitter to the receiver adapter (#35453) - (Contrib)
receiver/prometheus
: Fix prometheus receiver to support static scrape config with Target Allocator (#36062)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.114.0
- digest:
sha256:bb2a8cb7e0ba9567f4f3af2be57787220ff808db258b53bd6bcb7d691efda93b
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.114.0
- digest:
sha256:866331331dfdc8ee6ac53537a5211f2c82891b0388fe944001d7e6b474efd502
v0.113.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.113.0 and the opentelemetry-collector-contrib v0.113.0 releases where appropriate.
🛑 Breaking changes 🛑
- (Contrib)
sapmreceiver
: Remove the deprecated access_token_passthrough from SAPM receiver. (#35972)
Please useinclude_metadata
instead with the following config option applied to the batch processor:
batch:
metadata_keys: [X-Sf-Token]
- (Contrib)
pkg/ottl
: Promoteprocessor.transform.ConvertBetweenSumAndGaugeMetricContext
feature gate to Stable (#36216)
This gate can no longer be disabled. Theconvert_sum_to_gauge
andconvert_gauge_to_sum
may now only be used with themetric
context.
💡 Enhancements 💡
- (Contrib)
splunkenterprisereceiver
: Add telemetry around the Splunk Enterprise kv-store. (#35445) - (Contrib)
journaldreceiver
: adds ability to parse journald's MESSAGE field as a string if desired (#36005) - (Contrib)
journaldreceiver
: allows querying a journald namespace (#36031) - (Contrib)
hostmetricsreceiver
: Add the system.uptime metric in the hostmetrics receiver (#31627)
This metric is provided by the newsystem
scraper. - (Contrib)
hostmetrics
: Adjust scraper creation to make it so the scraper name is reported with hostmetrics scraper errors. (#35814) - (Contrib)
pkg/ottl
: Add SliceToMap function (#35256) - (Contrib)
journaldreceiver
: Restart journalctl if it exits unexpectedly (#35635) - (Contrib)
routingconnector
: Add ability to route by request metadata. (#19738) - (Contrib)
exporter/signalfx
: Enabling retrying for dimension properties update without tags in case of 400 response error. (#36044)
Property and tag updates are done using the same API call. After this change, the exporter will retry once to sync
properties in case of 400 response error. - (Contrib)
signalfxexporter
: Add more default metrics related to Kubernetes cronjobs, jobs, statefulset, and hpa (#36026) - (Contrib)
simpleprometheusreceiver
: Support to setjob_name
in config (#31502) - (Contrib)
solacereceiver
: Add support to the Solace Receiver to convert the newMove to Dead Message Queue
and newDelete
spans generated by Solace Event Broker to OTLP. (#36071) - (Contrib)
routingconnector
: Add ability to route log records individually using OTTL log record context. (#35939) - (Contrib)
splunkenterprisereceiver
: Add new metrics for Splunk Enterprise dispatch artifacts (#35950) - (Core)
batchprocessor
: Move single shard batcher creation to the constructor (#11594) - (Core)
service
: add support for using the otelzap bridge and emit logs using the OTel Go SDK (#10544)
🧰 Bug fixes 🧰
- (Contrib)
receiver/windowseventlog
: Fix panic when rendering long event messages. (#36179) - (Contrib)
hostmetricsreceiver
: Do not set the default value of HOST_PROC_MOUNTINFO to respect root_path (#35990) - (Contrib)
prometheusexporter
: Fixes an issue where the prometheus exporter would not shut down the server when the collector was stopped. (#35464) - (Contrib)
k8sobserver
: Enable observation of ingress objects if theObserveIngresses
config option is set to true (#35324) - (Contrib)
pkg/stanza
: Fixed bug causing Operators with DropOnErrorQuiet to send log entries to the next operator. (#35010)
This issue was introduced by a bug fix meant to ensure Silent Operators are not logging errors (#35010). With this fix,
this side effect bug has been resolved. - (Contrib)
splunkhecreceiver
: Avoid a memory leak by changing how we record obsreports for logs and metrics. (#35294) - (Contrib)
receiver/filelog
: fix record counting with header (#35869) - (Contrib)
connector/routing
: Fix detection of duplicate conditions in routing table. (#35962) - (Contrib)
solacereceiver
: The Solace receiver may unexpectedly terminate on reporting traces when used with a memory limiter processor and under high load (#35958) - (Contrib)
pkg/stanza/operator
: Retain Operator should propagate the severity field (#35832)
The retain operator should propagate the severity field like it does with timestamps. - (Contrib)
pkg/stanza
: Handle error of callback function ofParserOperator.ProcessWithCallback
(#35769)
ProcessWithCallback
ofParserOperator
first calls theParseWith
method
which properly handles errors withHandleEntryError
.
Then the callback function is called and its returned error should also
be handled by theHandleEntryError
ensuring a consistent experience. - (Core)
service
: ensure traces and logs emitted by the otel go SDK use the same resource information (#11578) - (Core)
config/configgrpc
: Patch for bug in the grpc-go NewClient that makes the way the hostname is resolved incompatible with the way proxy setting are applied. (#11537)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.113.0
- digest:
sha256:d5758bd96efd837be26c2351f740a9e7723241bdccb6374b14d18da0a274fbd1
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.113.0
- digest:
sha256:f4ae66b62f79c75a56fd731de672003efcd50323b7fc02526f16461601567e5f
v0.112.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.112.0 and the opentelemetry-collector-contrib v0.112.0 releases where appropriate.
🛑 Breaking changes 🛑
- (Splunk) Remove httpsink exporter (#5503)
- (Splunk) Remove signalfx-metadata and collectd/metadata monitors (#5508)
Both monitors are deprecated and replaced by the hostmetricsreceiver and processlist monitor. - (Splunk) Remove deprecated collectd/etcd monitor. Please use the etcd prometheus endpoint to scrape metrics. (#5520)
- (Splunk) Remove deprecated collectd/health-checker monitor. (#5522)
- (Splunk) Remove deprecated loggingexporter from the distribution (#5551)
- (Core)
service
: Remove stable gate component.UseLocalHostAsDefaultHost (#11412)
🚩Deprecations 🚩
- (Splunk) Deprecate cloudfoundry monitor (#5495)
- (Splunk) Deprecate the heroku observer. Use the resource detection observer with heroku detector instead. (#5496)
- (Splunk) Deprecate mongodb atlas monitor. Please use the mongodbatlasreceiver instead (#5500)
- (Splunk) Deprecate python-monitor monitor (#5501)
- (Splunk) Deprecate windowslegacy monitor (#5518)
- (Splunk) Deprecate statsd monitor. Use the statsd receiver instead. (#5513)
- (Splunk) Deprecate the collectd/consul monitor. Please use the statsd or prometheus receiver instead. See https://developer.hashicorp.com/consul/docs/agent/monitor/telemetry for more information. (#5521)
- (Splunk) Deprecate collectd/mysql monitor. Use the mysql receiver instead. (#5538)
- (Splunk) Deprecate the collectd/nginx monitor. Please use the nginx receiver instead. (#5537)
- (Splunk) Deprecate the collectd/chrony monitor. Please use the chronyreceiver instead. (#5536)
- (Splunk) Deprecate the collectd/statsd monitor. Please use the statsdreceiver instead. (#5542)
- (Splunk) Deprecate the ecs-metadata monitor (#5541)
- (Splunk) Deprecate the collectd/statsd monitor. Please use the statsdreceiver instead. (#)
- (Splunk) Deprecate the haproxy monitor. Please use the haproxyreceiver instead. (#5543)
- (Contrib)
sapmreceiver
: Deprecate SAPM receiver (#32125)
🚀 New components 🚀
- (Splunk) Add chrony receiver (#5535)
💡 Enhancements 💡
- (Splunk) Update Python to 3.13.0 (5552)
- (Core)
confighttp
: Adding support for lz4 compression into the project (#9128) - (Core)
service
: Hide profiles support behind a feature gate while it remains alpha. (#11477) - (Core)
exporterhelper
: Retry sender will fail fast when the context timeout is shorter than the next retry interval. (#11183) - (Contrib)
azureeventshubreceiver
: Updates the Azure Event Hub receiver to use the new Resource Logs translator. (#35357) - (Contrib)
pkg/ottl
: Add ConvertAttributesToElementsXML Converter (#35328) - (Contrib)
azureblobreceiver
: adds support for using azidentity default auth, enabling the use of Azure Managed Identities, e.g. Workload Identities on AKS (#35636)
This change allows to use authentication type "default", which makes the receiver use azidentity default Credentials,
which automatically picks up, identities assigned to e.g. a container or a VirtualMachine - (Contrib)
k8sobserver
: Emit endpoint per Pod's container (#35491) - (Contrib)
mongodbreceiver
: Add support for MongoDB direct connection (#35427) - (Contrib)
chronyreceiver
: Move chronyreceiver to beta (#35913) - (Contrib)
pkg/ottl
: Parsing invalid statements and conditions now prints all errors instead of just the first one found. (#35728) - (Contrib)
pkg/ottl
: Add ParseSimplifiedXML Converter (#35421) - (Contrib)
routingconnector
: Allow routing based on OTTL Conditions (#35731)
Each route must contain either a statement or a condition. - (Contrib)
sapmreceiver
: Respond 503 on non-permanent and 400 on permanent errors (#35300) - (Contrib)
hostmetricsreceiver
: Use HOST_PROC_MOUNTINFO as part of configuration instead of environment variable (#35504) - (Contrib)
pkg/ottl
: Add ConvertTextToElements Converter (#35364)
🧰 Bug fixes 🧰
- (Core)
processorhelper
: Fix issue where in/out parameters were not recorded when error was returned from consumer. (#11351) - (Contrib)
metricstransform
: The previously removed functionality of aggregating against an empty label set is restored. (#34430) - (Contrib)
filelogreceiver
: Supportsadd_metadata_from_filepath
for Windows filepaths (#35558) - (Contrib)
filelogreceiver
: Suppress errors on EBADF when unlocking files. (#35706)
This error is harmless and happens regularly when delete_after_read is set. This is because we acquire the lock right at the start of the ReadToEnd function and then defer the unlock, but that function also performs the delete. So, by the time it returns and the defer runs the file descriptor is no longer valid. - (Contrib)
kafkareceiver
: Fixes issue causing kafkareceiver to block during Shutdown(). (#30789) - (Contrib)
hostmetrics receiver
: Fix duplicate filesystem metrics (#34635, #34512)
The hostmetrics exposes duplicate metrics of identical mounts exposed in namespaces. The duplication causes errors in exporters that are sensitive to duplicate metrics. We can safely drop the duplicates as the metrics should be exactly the same. - (Contrib)
pkg/ottl
: Allow indexing string slice type (#29441) - (Contrib)
mysqlreceiver
: Add replica metric support for versions of MySQL earlier than 8.0.22. (#35217) - (Contrib)
stanza/input/windows
: Close remote session while resubscribing (#35577) - (Contrib) `...
v0.111.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.111.0 and the opentelemetry-collector-contrib v0.111.0 releases where appropriate.
🛑 Breaking changes 🛑
- (Contrib) signalfxexporter: Do not exclude the metric container.memory.working_set (#35475)
- (Contrib) sqlqueryreceiver: Fail if value for log column in result set is missing, collect errors (#35068)
- (Contrib) windowseventlogreceiver: The 'raw' flag no longer suppresses rendering info. (#34720)
- (Splunk) Remove deprecated memory ballast extension (#5429)
🚩Deprecations 🚩
- (Contrib) sapmreceiver: access_token_passthrough is deprecated (#35330)
- (Splunk) Remove ballast extension entirely from components (#5429)
- (Splunk) Deprecate jaegergrpc monitor (#5428)
- (Splunk) Deprecate the jaegergrpc monitor (#5428)
💡 Enhancements 💡
- (Splunk) Initial release of standalone collector binaries for Linux (amd64/arm64) and Windows (amd64) with FIPS 140-2 support. These are experimental (alpha) binaries, and it is not suitable to use them in production environments. (#5378):
otelcol-fips_linux_<amd64|arm64>
: Built withGOEXPERIMENT=boringcrypto
andcrypto/tls/fipsonly
.otelcol-fips_windows_amd64.exe
: Built withGOEXPERIMENT=cngcrypto
andrequirefips
(the collector will panic if FIPS is not enabled on the Windows host).- Smart Agent components are not currently supported.
- Download the binaries from the list of assets below.
- (Core)
confignet:
Add Profiles Marshaler to otlptext. (#11161) - (Contrib)
receivercreator:
Validate endpoint's configuration before starting receivers (#33145) - (Contrib)
receiver/statsd:
Add support for aggregating on Host/IP (#23809) - (Contrib)
hostmetricsreceiver:
Add ability to mute all errors (mainly due to access rights) coming from process scraper of the hostmetricsreceiver (#20435) - (Contrib)
kubeletstats:
Introduce feature gate for deprecation of container.cpu.utilization, k8s.pod.cpu.utilization and k8s.node.cpu.utilization metrics (#35139) - (Contrib)
pkg/ottl:
Add InsertXML Converter (#35436) - (Contrib)
pkg/ottl
: Add GetXML Converter (#35462) - (Contrib)
pkg/ottl
: Add ToKeyValueString Converter (#35334) - (Contrib)
pkg/ottl
: Add RemoveXML Converter (#35301) - (Contrib)
sqlserverreceiver:
Add computer name resource attribute to relevant metrics (#35040) - (Contrib)
windowseventlogreceiver:
Add 'suppress_rendering_info' option. (#34720) - (Contrib)
receiver/awss3receiver:
Add ingest progress notifications via OpAMP (#33980) - (Contrib)
receiver/azureblobreceiver:
support for default auth (#35636) - (Contrib) update sapm-proto to 0.16.0 (#35630)
🧰 Bug fixes 🧰
- (Contrib)
windowseventlogreceiver:
While collecting from a remote windows host, the stanza operator will no longer log "subscription handle is already open" constantly during successful collection. (#35520) - (Contrib)
windowseventlogreceiver:
If collecting from a remote host, the receiver will stop collecting if the host restarts. This change resubscribes when the host restarts. (#35175) - (Contrib)
sqlqueryreceiver:
Fix reprocessing of logs when tracking_column type is timestamp (#35194) - (Core)
processorhelper
: Fix bug where record in/out metrics were skipped (#11360)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.111.0
- digest:
sha256:7633ea95d144e63eb3624070be1e3821925a0c3ad9a733ae00b38178bf35c541
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.111.0
- digest:
sha256:ca065a7626d31c7c8b31b1ce33385b7b8d2b0231b58c87171ead73365c1be9f6
v0.110.0
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.110.0 and the opentelemetry-collector-contrib v0.110.0 releases where appropriate.
Additionally, updates splunk-otel-javaagent
to v2.8.1
and jmx-metric-gatherer
to v1.39.0
🛑 Breaking changes 🛑
- (Core)
processorhelper
: Update incoming/outgoing metrics to a single metric withotel.signal
attributes. (#11144) - (Core) processorhelper: Remove deprecated [Traces|Metrics|Logs]Inserted funcs (#11151)
- (Core) config: Mark UseLocalHostAsDefaultHostfeatureGate as stable (#11235)
- (Contrib)
pkg/stanza
: Move filelog.container.removeOriginalTimeField feature gate to beta. Disable the filelog.container.removeOriginalTimeField feature gate to get the old behavior. (#33389) - (Contrib)
resourcedetectionprocessor
: Move processor.resourcedetection.hostCPUSteppingAsString feature gate to stable. (#31136) - (Contrib)
resourcedetectionprocessor
: Remove processor.resourcedetection.hostCPUModelAndFamilyAsString feature gate. (#29025)
🚩 Deprecations 🚩
- (Core)
processorhelper
: deprecate accepted/refused/dropped metrics (#11201) - (Contrib)
hostmetricsreceiver
: Set the receiver.hostmetrics.normalizeProcessCPUUtilization feature gate to stable. (#34763)
💡 Enhancements 💡
- (Core)
confignet
: Mark module as Stable. (#9801) - (Core)
confmap/provider/envprovider
: Support default values when env var is empty (#5228) - (Core)
service/telemetry
: Mark useOtelWithSDKConfigurationForInternalTelemetry as stable (#7532) - (Contrib)
processor/transform
: Add custom function to the transform processor to convert exponential histograms to explicit histograms. (#33827) - (Contrib)
file_storage
: provide a new option to the user to create a directory on start (#34939) - (Contrib)
headersetterextension
: adding default_value config.default_value
config item applied in case context value is empty. (#34412) - (Contrib)
kafkaexporter
: Add support for encoding extensions in the Kafka exporter. This change adds support for encoding extensions in the Kafka exporter. Loading extensions takes precedence over the internally supported encodings. (#34384) - (Contrib)
kafkareceiver
: Add support for otlp_json encoding to Kafka receiver. The payload is deserialized into OpenTelemetry traces using JSON format. This encoding allows the Kafka receiver to handle trace data in JSON format, enabling integration with systems that export traces as JSON-encoded data. (#33627) - (Contrib)
pkg/ottl
: Improved JSON unmarshaling performance by 10-20% by switching dependencies. (#35130) - (Contrib)
pkg/ottl
: Added support for locale in the Time converter (#32978) - (Contrib)
remotetapprocessor
: Origin header is no longer required for websocket connections (#34925) - (Contrib)
deltatorateprocessor
: Remove unnecessary data copies. (#35165) - (Contrib)
transformprocessor
: Remove unnecessary data copy when transform sum to/from gauge (#35177) - (Contrib)
sapmexporter
: Prioritize token in context when accesstokenpassthrough is enabled (#35123) - (Contrib)
tailsamplingprocessor
: Fix the behavior for numeric tag filters with inverse_match set to true. (#34296) - (Splunk) Update instruction for partial discovery (#5402)
🧰 Bug fixes 🧰
- (Core)
service
: Ensure process telemetry is registered when internal telemetry is configured with readers instead of an address. (#11093) - (Contrib)
splunkenterprise
: Fix a flaky search related to iops metrics. (#35081) - (Contrib)
azuremonitorexporter
: fix issue for property endpoint is ignored when using instrumentation_key (#33971) - (Contrib)
groupbytraceprocessor
: Ensure processor_groupbytrace_incomplete_releases metric has a unit. (#35221) - (Contrib)
deltatocumulative
: do not drop gauges and summaries. Gauges and Summaries are no longer dropped from processor output. Instead, they are passed through as-is. (#35284) - (Contrib)
pkg/stanza
: Do not get formatted message for Windows events without an event provider. Attempting to get the formatted message for Windows events without an event provider can result in an error being logged. This change ensures that the formatted message is not retrieved for such events. (#35135) - (Contrib)
signalfxexporter
: Ensure token is not sent through for event data (#35154) - (Contrib)
prometheusreceiver
: Fix the retrieval of scrape configurations by also considering scrape config files (#34786) - (Contrib)
redactionprocessor
: Fix panic when using the redaction processor in a logs pipeline (#35331) - (Contrib)
exporter/splunkhec
: Fix incorrect claim that the exporter doesn't mutate data when batching is enabled. The bug lead to runtime panics when the exporter was used with the batcher enabled in a fanout scenario. (#35306) - (Splunk) Choco upgrade should preserve collector service custom env vars (#5386)
- (Splunk)
discoveryreceiver
withsplunk.continuousDiscovery
feature gate enabled: Remove redundant discovery.receiver.rule attribute (#5403) - (Splunk)
discoveryreceiver
withsplunk.continuousDiscovery
feature gate enabled: Remove redundant resource attributes (#5409)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.110.0
- digest:
sha256:0dbcef5a534ad26eaf9e817b5726cadca129cfce6e2540778132162807df589a
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.110.0
- digest:
sha256:3231af8709d3f9f0afdbe69c8cb5583885e5005a0f10c8f62e9e3602241ea8b0
v0.109.0
🛑 Breaking changes 🛑
- (Splunk) Update Python to 3.12.5 in the Smart Agent bundle for Linux and Windows. Check What’s New In Python 3.12 for details. (#5298)
- (Contrib)
spanmetricsconnector
: Improve consistency between metrics generated by spanmetricsconnector. Added traces.span.metrics as default namespace (#33227
Default namespace for the generated metrics is traces.span.metrics now. | The deprecated metrics are: calls, duration and events. | The feature flag connector.spanmetrics.legacyLatencyMetricNames was added to revert the behavior. - (Contrib)
ottl
: Remove tracing from OTTL due to performance concerns (#34910
🚀 New components 🚀
💡 Enhancements 💡
- (Splunk) Apache Web Server Auto Discovery: set the default discovered endpoint to match the OpenTelemetry
apachereceiver
default:http://
endpoint/server-status?auto
(#5353)
If the collector is running as a process on the host OS and the Apache Web Server is in a Docker container add--set=splunk.discovery.extensions.docker_observer.config.use_host_bindings=true
to the command-line arguments for the discovery to create the correct endpoint. - (Splunk) Introduce continuous service discovery mode. This mode can be enabled with a feature gate by adding
--feature-gates=splunk.continuousDiscovery
command line argument. (#5363)
The new mode does the following:- It allows discovering new services that were not available at the time of the collector startup. If discovery is
successful, the metrics collection will be started. - Information about discovered services is being sent to Splunk Observability Cloud. The information will include
instructions to complete discovery for particular services if the discovery was not successful out of the box.
- It allows discovering new services that were not available at the time of the collector startup. If discovery is
- (Core)
service
: moveuseOtelWithSDKConfigurationForInternalTelemetry
gate to beta (#11091) - (Core)
service
: implement a no-op tracer provider that doesn't propagate the context (#11026)
The no-op tracer provider supported by the SDK incurs a memory cost of propagating the context no matter
what. This is not needed if tracing is not enabled in the Collector. This implementation of the no-op tracer
provider removes the need to allocate memory when tracing is disabled. - (Core)
processor
: Add incoming and outgoing counts for processors using processorhelper. (#10910)
Any processor using the processorhelper package (this is most processors) will automatically report
incoming and outgoing item counts. The new metrics are:- otelcol_processor_incoming_spans
- otelcol_processor_outgoing_spans
- otelcol_processor_incoming_metric_points
- otelcol_processor_outgoing_metric_points
- otelcol_processor_incoming_log_records
- otelcol_processor_outgoing_log_records
- (Contrib)
pkg/ottl
: Added Decode() converter function (#32493 - (Contrib)
filestorage
: Add directory validation for compaction on-rebound (#35114 - (Contrib)
windowseventlogreceiver
: Avoid rendering the whole event to obtain the provider name (#34755 - (Contrib)
splunkhecexporter
: Drop empty log events (#34871
Log records with no body are dropped by Splunk on reception as they contain no log message, albeit they may have attributes.
This is in tune with the behavior of splunkhecreceiver, which refuses HEC events with no event (#19769 - (Contrib)
transformprocessor
: Support aggregating metrics based on their attribute values and substituting the values with a new value. (#16224 - (Contrib)
kafkareceiver
: Adds tunable fetch sizes to Kafka Receiver (#22741
Adds the ability to tune the minumum, default and maximum fetch sizes for the Kafka Receiver - (Contrib)
kafkareceiver
: Add support for encoding extensions in the Kafka receiver. (#33888
This change adds support for encoding extensions in the Kafka receiver. Loading extensions takes precedence over the internally supported encodings. - (Contrib)
pkg/ottl
: AddSort
function to sort array to ascending order or descending order (#34200 - (Contrib)
redactionprocessor
: Add support for logs and metrics (#34479 - (Contrib)
spanmetricsconnector
: Extract thegetDimensionValue
function as a common function. (#34627 - (Contrib)
sqlqueryreceiver
: Support populating log attributes from sql query (#24459
🧰 Bug fixes 🧰
- (Core)
configgrpc
: Change the value of max_recv_msg_size_mib from uint64 to int to avoid a case where misconfiguration caused an integer overflow. (#10948) - (Core)
exporterqueue
: Fix a bug in persistent queue that Offer can becomes deadlocked when queue is almost full (#11015) - (Contrib)
apachereceiver
: Fix panic on invalid endpoint configuration (#34992 - (Contrib)
fileconsumer
: Fix bug where max_concurrent_files could not be set to 1. (#35080 - (Contrib)
hostmetricsreceiver
: In filesystem scraper, do not prefix partitions when using the environment variable HOST_PROC_MOUNTINFO (#35043 - (Contrib)
splunkhecreceiver
: Fix memory leak when the receiver is used for both metrics and logs at the same time (#34886 - (Contrib)
pkg/stanza
: Synchronize shutdown in stanza adapter (#31074
Stanza-based receivers should now flush all data before shutting down - (Contrib)
sqlserverreceiver
: Fix bug where metrics were being emitted with the wrong database name resource attribute (#35036 - (Contrib)
signalfxexporter
: Fix memory leak by re-organizing the exporter's functionality lifecycle (#32781 - (Contrib)
otlpjsonconnector
: Handle OTLPJSON unmarshal error (#34782 - (Contrib)
mysqlreceiver
: mysql client raise error when the TABLE_ROWS column is NULL, convert NULL to int64 (#34195 - (Contrib)
pkg/stanza
: An operator configured with silent errors shouldn't log errors while processing log entries. (#35008
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.109.0
- digest:
sha256:0f8ef18872f42623e5129c9ffad4ceae04bbf2b42d6d924f507706b3557c73db
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.109.0
- digest:
sha256:9be93047532dc4bf5f5432307cdc47124ac5768eb22cee0fa6bce3ab8ee88903
v0.108.1
This Splunk OpenTelemetry Collector release includes changes from the opentelemetry-collector v0.108.1 and the opentelemetry-collector-contrib v0.108.0 releases where appropriate.
🚩Deprecations 🚩
- (Splunk) Deprecate the nagios monitor (#5172)
🧰 Bug fixes 🧰
- (Splunk) Discovery observers start failures should not stop the collector (#5299)
Docker Image Manifests:
- Linux (amd64, arm64, ppc64le) and Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector:0.108.1
- digest:
sha256:e8004468b506907748cdc7475578844097934a73320feec3b0efac4ff882a559
- Windows (2019 amd64, 2022 amd64):
quay.io/signalfx/splunk-otel-collector-windows:0.108.1
- digest:
sha256:3db675d4fffee375e51133efad0f8f1eb40cbba0cfdd46da96714bb35e4e6a63