All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
Unreleased section should follow Release Toolkit
- Updated golang.org/x/net to v0.33.0
- Added FIPS compliant packages
- Updated golang patch version to v1.23.4
- Updated kubernetes packages to v0.31.1
- Updated github.com/prometheus/client_model to v0.6.1 - Changelog 🔗
- Updated golang version to v1.23.1
- Updated golang version to v1.22.5
- Updated github.com/spf13/viper to v1.19.0 - Changelog 🔗
- Updated golang version to v1.22.3
- Updated golang version to v1.22.2
- Added XPrometheusHeader to allow exporters to give up complex computation when needed.
- Updated github.com/prometheus/client_golang to v1.18.0 - Changelog 🔗
- Skip prometheus services with non-existing port
- Updated github.com/spf13/viper to v1.18.2 - Changelog 🔗
- updated go to 1.21
- updated several dependencies
- Updated github.com/containerd/containerd to v1.7.5 - Changelog 🔗
- Updated github.com/containerd/containerd to v1.7.3 - Changelog 🔗
- Updated golang to v1.20.7
- Updated go to 1.20
- Updated kubernetes packages to v0.27.3
- Updated github.com/prometheus/client_golang to v1.16.0 - Changelog 🔗
- Updated github.com/containerd/containerd to v1.7.2 - Changelog 🔗
- Updated github.com/sirupsen/logrus to v1.9.3 - Changelog 🔗
- Updated github.com/spf13/viper to v1.16.0 - Changelog 🔗
- Updated github.com/stretchr/testify to v1.8.4 - Changelog 🔗
- Updated github.com/prometheus/client_model to v0.4.0 - Changelog 🔗
- Updated kubernetes packages to v0.27.2
- Updated github.com/prometheus/common to v0.44.0 - Changelog 🔗
- Updated github.com/sirupsen/logrus to v1.9.2 - Changelog 🔗
- Updated github.com/stretchr/testify to v1.8.3 - Changelog 🔗
- Updated alpine to v3.18
- Updated github.com/containerd/containerd to v1.7.1 - Changelog 🔗
- Upgraded google.golang.org/protobuf from 1.29.0 to 1.29.1
- Upgrade Go to 1.19 and bump dependencies
- Exposed
self_metrics_listening_address
to set listening address for self-metrics, having as default:8080
. - Several dependencies updated
- Several dependencies updated
- Updated go to 1.19
- Several dependencies updated
- #344 The Bug was caused by a wrong implementation of the filtering feature.
In particular, it was not possible having
lowDataMode=true
to filter out everything including just some metrics.
- Several dependencies updated
- Several dependencies updated
- Several dependencies updated
- The
use_bearer
config is now exposed the config for static targets by @paologallinaharbur in #327
- AcceptHeader was including
application/openmetrics-text
that was not fully supported by the nri-prometheus parser
- Query params were not included if port was specified by @paologallinaharbur in #301
- Query parameters, such as
?format=prometheus
, can now be specified in theprometheus.io/path
label/annotation
- Added
UseBearer
flag and set it to true for nodes by @roobre in #264 - chore(deps): bump github.com/prometheus/common from 0.32.1 to 0.33.0 by @dependabot in #271
- chore(deps): bump golangci/golangci-lint-action from 2 to 3.1.0 by @dependabot in #261
- Bump SDK version
- Remove entity synthesis and add ignoreEntity flag.
- Host replacer to be on emitter replacing targetName and scrapedTargetName if nriHostID is set and host=localhost
- Add Prometheus accept header by @gsanchezgavier in #253
- chore(deps): bump github.com/prometheus/client_golang from 1.11.0 to 1.12.1 by @dependabot in #251
- Updated dependencies
- Add the ability to ignore metrics by type by @smcavallo in #238
- Add support for prometheus.io/scheme by @vihangm in #240
- Remove static manifests from this repo by @kang-makes in #237
- Improve formatting in packages and make imports more consistent by @invidian in #197
- Bump Dependencies.
- Dependency have been bumped. Notably, this includes a new version of the telemetry sdk which should improve performance when submitting metrics from large targets. #220
- Updated manifest in preparation of 1.22 support #220
- infraSDK should use Cumulative Count to send deltas
- metadata is read from config in order to set integration version and name from an external source
- latest image is now published
- Improved entity synthesis to be uniform with different projects
- Improved common attributes management
- Several non-critical dependencies have been updated to their latest versions (#175)
- Prometheus dependencies have been upgraded to their latest version (#176)
- Kubernetes client dependencies have been upgraded to latest available versions (#179)
- Fixed a bug that caused
nri-prometheus
to panic ifprometheus.io/path
was set to an empty string (#182)- An empty value for
prometheus.io/path
will now be intepreted as/
path.
- An empty value for
- Several dependencies have been bumped to their latest versions
While services with the a prometheus.io/scrape annotation can be discovered, nri-prometheus used to scrape only the service itself and not service endpoints.
Two new config options have been added ScrapeServices (default true) and ScrapeEndpoints(default false). Please notice that enabling the latter depending the number of endpoints in the cluster can increase considerably the load.
Moreover unless there is the need for backward compatibility there is no reason for having both options set to true
- When a page is partially loaded, an unexpected EOF error is raised, but is squashed by the prometheus decoder. This PR exposes the unexpected EOF error (io.ErrUnexpectedEOF) and avoids only partially reporting metrics which can lead to weird behavior of metrics that are compositions in the UI.
- Removed definition path from configuration file
- Added support for ARM and ARM64 images
- Fixed name structure for tar.gz packages
- Upgrade base image to
alpine:3.12
(#135) - Expose advanced config flags in sample yaml files (#131)
- Update infra SDK to v4 stable (#128)
- Implemented automated load testing for regression tests (#109, #112, #126)
- Fixed a bug that caused nri-prometheus to consume too much memory if too much data was ingested per unit of time (#124)
- Fixed a bug in the telemtry-sdk which caused big metric payloads to fail to fail to be reported in some rare cases (#127)
- Fixed a bug in the release pipeline that caused K8s manifests to not be upload to download.newrelic.com (#125)
- Fixed a bug that caused the integration version to be reported as
dev
(#122)
b2f8b87 fix: summary "sum" metric must also be sent as delta (#101) 181024e fix: resetting metrics to avoid leakage (#98) a316f58 fix: update sdk fixes count type metrics agent error (#96) 108d60f feat: accept duplicated service definitions (#94) fffc410 fix: ensuring ordering of labels (#89) 568957c fix: Entity type format changed (#88) 120c78d fix: rename dimensions to labels in entity properties (#87)
- Various performance improvements
- Adjustable fetcher worker threads
- Default configs emitter and definition path
- Use personal token for helm bumper
- Upgrade the Go Telemetry SDK to version 0.4.0 to fix an issue with retrying failed requests.
The way how Summary and Histogram metric types has been changed, they are sent as they come from Prometheus, without adding custom suffixes or calculating percentiles from the integration side:
- xxx_bucket is ingested as a Counter (converted to a delta rather than accumulative). Metrics containing dimension "le" == '+Inf' are also sent, we don't omit them.
- xxx_count is passed through as a Counter (converted to a delta rather than accumulative).
- xxx_total passed through as a Counter (converted to a delta rather than accumulative).
- xxx_sum is passed through as a NR Summary converted to a delta rather than accumulative, Min and Max here should be NaN. Its value can be negative. The count field of the summary should be 1.
- For Prometheus summary metrics, we report the quantile as a dimension and we don't add a "percentile" dimension.
- Change the default for the New Relic telemetry emitter delta calculator
expiration age and expiration check interval to 5 minutes. These values can
now be configured with the following options
telemetry_emitter_delta_expiration_age
andtelemetry_emitter_delta_expiration_check_interval
. This solves the issue with missing counters when the scrape interval takes more than the hard-coded 30 minutes values that we had previously. - Use go modules instead of govendor for managing project dependencies.
- Redact the password from URLs using simple authentication when storing target metadata.
- Encoding of URL parameter is the annotation/label
prometheus.io/path
is fixed.
- Upgrade the Go Telemetry SDK to version 0.2.0 to fix an issue with NaN values.
- Obfuscate the license key when logging the configuration. Running on debug
mode prints the configuration object, this included the license key, to
prevent users from leaking their credentials when sharing their logs for
troubleshooting, if the license key is used in any kind of to string, print
or log statement the symbol
****
will be returned.
- The transformation located in the
nri-prometheus-cfg
config map of the deploy manifest template is commented by default. It's left in the manifest as an example on how to use transformations. Installing with the new manifest will not filter metrics and everything will be sent to the New Relic platform.
- Fixed a bug that caused newly created pods without a valid podIP to be discovered and cached, and not be scraped unless nri-prometheus was restarted.
- Skip the check for the
emitter_ca_file
if it's empty.
- Support for HTTP(S) proxy for the emitters via the config options
emitter_proxy
,emitter_ca_file
andemitter_insecure_skip_verify
. - Reconnect support when resource watcher connection is dropped.
- Add support for Histograms and Summaries following New Relic's guidelines for higher-level metric abstractions.
- Fix and refactor self describing metrics
- Fix how the scrape interval is respected.
- Decorate samples with
k8s.cluster.name
.
- Logic for target discovery was adding nodes even when they were not labelled and required a label to be scraped.
- The
SCRAPE_DURATION
time is respected even when the scrape cycle might finish earlier.
- Support for scraping static targets using (mutual) TLS authentication.
- By default do not skip the TLS verification.
- Revamp of the static target configuration:
endpoints
key renamed totargets
. If you had endpoints configured before, you need to update your configuration and restart the scraper.- Each item in target can contain one or many urls in the
urls
key. This key is always a list. - Each target hosts its own TLS configuration in the
tls_config
key. - The TLS configuration contains 3 keys:
ca_file_path
,cert_file_path
andkey_file_path
- Rename rules are executed at the end of the transformations pipeline. Now Copy attributes rules are being executed before it, so the name of metrics being used for matching the source and the dest match with the original scraped instead of the renamed one.
- Static targets cannot be configured via environment variables anymore, as it requires a complex structure now. See the Changed section for more information.
- The Telemetry Emitter now correctly handles counter metrics.
- Integration benchmark
scrape_duration
configuration option to specify the length in time to distribute the scraping from the endpoints.- Ignore rule accepts now exceptions.
- Delta calculator memory optimization
- Avoid growing slices when converting from Prometheus metrics to our internal DTO by setting the final capacity. This reduces memory allocs.
- Optimized Target Metadata generation
- Distributed targets fetching on time, to avoid memory peaks and big heaps.
- Putting processing rules in contiguous memory to decrease the working set of the process.
- Emitters are now responsible for any delta calculation.
- The default emitter now is the Go Telemetry SDK.
- Unused
RawMetrics
field fromTargetMetrics
data structure.
- Transformation rule to add static attributes, i.e. a cluster name, through the configuration.
- Default attributes to decorate the metrics with:
clusterName
,integrationVersion
andintegrationName
. - Mount pprof http endpoints when running in debug mode.
targetName
attribute added to the metrics when converting from Prometheus metrics.- Integration benchmark
- Now convert Prometheus metric types to our own types in the fetchers.
- Emitters now receive
Metric
s instead ofObservation
s to avoid coupling with the format of especific emitters. - Convert Prometheus
counter
s into New Reliccount
s - Adapter the fetcher to use the worker concurrency pattern instead of starting blocked go routines.
nrMetricName
andnrMetricType
aren't added as metric attributes anymore. This is done by the Metric API.metadata
field removed from theMetric
type.labels
field removed from theTarget
type.- The parallel emitter has been removed.
- Now listing pods when looking for targets.
- The Kubernetes target retriever now removes targets if their scrape label is removed or not
true
anymore.
- StartTimeMs is now generated correctly.
- StartTimeMs values are correctly sent as milliseconds.
- Update the Kubernetes retriever to continue watching the objects when there is an error listing them.
- Transformations config format
- Internal refactoring
- Add support for reading config options from a configuration file
- Read processing rules from the config file
- Rename URL config option and its default value
- Modify docker images to don't use the root user
- Added more rename attributes for known exporters
- Prefix metric attributes that are coming from K8s object labels
- Removed "entityName" attribute from all the metrics
- Log error when a request to the metric API is not successful
- Support for K8s clusters using RBAC
- Rename the attribute with info about the scraped endpoint
- Decorate metrics from K8s targets with K8s context attributes
- Add option to decorate metrics automatically
- Ignore unsupported metric type
- Send Prometheus untyped metrics as gauges
- Renamed the integration
- Emitters: "api" and "stdout"
- Configurable list of static endpoints
- Integration metrics
- Refactor: Decoupled data processing pipeline
- v0.3.0 metrics format
- Watch Kubernetes objects
- New Relic infrastructure agent dependency
- Initial version