-
Notifications
You must be signed in to change notification settings - Fork 3.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Alan Clucas <[email protected]>
- Loading branch information
Showing
64 changed files
with
3,199 additions
and
1,495 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
# Metrics upgrade notes | ||
|
||
Metrics have changed between 3.5 and 3.6. | ||
|
||
You can now retrieve metrics using the OpenTelemetry Protocol using the [OpenTelemetry collector](https://opentelemetry.io/docs/collector/), and this is the recommended mechanism. | ||
|
||
These notes explain the differences in using the prometheus `/metrics` endpoint to scrape metrics for a minimal effort upgrade. It is not recommended you follow this guide blindly, the new metrics have been introduced because they add value, and so they should be worth collecting and using. | ||
|
||
## TLS | ||
|
||
The prometheus `/metrics` endpoint defaults to TLS on. | ||
|
||
To disable this set `.metricsConfig.secure` to `false`. | ||
|
||
## New metrics | ||
|
||
The following are new metrics: | ||
|
||
* `argo_workflows_build_info` | ||
* `argo_workflows_total_count` | ||
* `argo_workflows_pods_total_count` | ||
* `argo_workflows_controller_build_info` | ||
* `argo_workflows_cronworkflows_triggered_total` | ||
* `argo_workflows_workflowtemplate_triggered_total` | ||
* `argo_workflows_workflowtemplate_runtime` | ||
* `argo_workflows_k8s_request_duration` | ||
* `argo_workflows_queue_duration` | ||
* `argo_workflows_queue_longest_running` | ||
* `argo_workflows_queue_retries` | ||
* `argo_workflows_queue_unfinished_work` | ||
* `argo_workflows_pod_pending` | ||
|
||
and can be disabled with | ||
|
||
```yaml | ||
metricsConfig: | ||
options: | ||
argo_workflows_build_info: | ||
disable: true | ||
argo_workflows_total_count: | ||
disable: true | ||
argo_workflows_pods_total_count: | ||
disable: true | ||
argo_workflows_controller_build_info: | ||
disable: true | ||
argo_workflows_cronworkflows_triggered_total: | ||
disable: true | ||
argo_workflows_workflowtemplate_triggered_total: | ||
disable: true | ||
argo_workflows_workflowtemplate_runtime: | ||
disable: true | ||
argo_workflows_k8s_request_duration: | ||
disable: true | ||
argo_workflows_queue_duration: | ||
disable: true | ||
argo_workflows_queue_longest_running: | ||
disable: true | ||
argo_workflows_queue_retries: | ||
disable: true} | ||
argo_workflows_queue_unfinished_work: | ||
disable: true | ||
argo_workflows_pod_pending: | ||
disable: true | ||
``` | ||
## Renamed metrics | ||
If you are using these metrics in your recording rules, dashboards or alerts you will need to use their new name after the upgrade: | ||
| Old name | New name | | ||
|------------------------------------|------------------------------------| | ||
| `argo_workflows_count` | `argo_workflows_gauge` | | ||
| `argo_workflows_pods_count` | `argo_workflows_pods_gauge` | | ||
| `argo_workflows_queue_depth_count` | `argo_workflows_queue_depth_gauge` | | ||
| `log_messages` | `argo_workflows_log_messages` | | ||
|
||
## Custom metrics | ||
|
||
Custom metric names and labels must be valid prometheus and OpenTelemetry names now. This prevents the use of `:`, which was usable in earlier versions of workflows | ||
|
||
Custom metrics, as defined by a workflow, could be defined as one type (say counter) in one workflow, and then as a histogram of the same name in a different workflow. This would work in 3.5 if the first usage of the metric had reached TTL and been deleted. This will no-longer work in 3.6, and custom metrics may not be redefined. It doesn't really make sense to change a metric in this way, and the OpenTelemetry SDK prevents you from doing so. |
Oops, something went wrong.