From c9ef93e9a0e912cb8681f9acd52a43c05bd2d2d2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=80=9Cnico-shishkin=E2=80=9D?= <“nicoshishkinatlogz@outlook.com”> Date: Thu, 13 Jun 2024 15:46:57 +0100 Subject: [PATCH] Updated App360 docs --- docs/shipping/App360/App360.md | 296 +++++++++++ docs/shipping/Other/App360.md | 866 --------------------------------- 2 files changed, 296 insertions(+), 866 deletions(-) create mode 100644 docs/shipping/App360/App360.md delete mode 100644 docs/shipping/Other/App360.md diff --git a/docs/shipping/App360/App360.md b/docs/shipping/App360/App360.md new file mode 100644 index 00000000..b63f560e --- /dev/null +++ b/docs/shipping/App360/App360.md @@ -0,0 +1,296 @@ +--- +id: Service-Performance-Monitoring-App360 +title: Service Performance Monitoring via App360 +overview: This integration allows you to configure App360 Service Performance Monitoring with OpenTelemetry collector and send spans and span metrics from your OpenTelemetry installation to Logz.io. +product: ['tracing'] +os: ['windows', 'linux'] +filters: ['Other'] +logo: https://logzbucket.s3.eu-west-1.amazonaws.com/logz-docs/shipper-logos/span-metrics.png +logs_dashboards: [] +logs_alerts: [] +logs2metrics: [] +metrics_dashboards: ['40ZpsSfzfGhbguMYoxwOqm', '5PFq9YHx2iQkwVMLCMOmjJ'] +metrics_alerts: [] +drop_filter: [] +--- + + + +[App360](https://docs.logz.io/docs/user-guide/distributed-tracing/spm/) is a high-level monitoring dashboard within Logz.io that enables you to monitor your tracing services and operations. This integration allows you to configure Service Performance Monitoring with OpenTelemetry collector and send spans and App360 span metrics from your OpenTelemetry installation to Logz.io. + +{@include: ../../_include/metric-shipping/custom-dashboard.html} Install the pre-built dashboard to enhance the observability of your metrics. + + + + + +{@include: ../../_include/metric-shipping/generic-dashboard.html} + + + +## Architecture overview + +This integration is based on OpenTelemetry. It works as an add-on to existing OpenTelemetry installations. If you need to set up OpenTelemetry first, refer to our documentation on [OpenTelemetry](https://app.logz.io/#/dashboard/integrations/OpenTelemetry-data). + +The integration includes: + +* Configuring the OpenTelemetry collector to receive spans generated by your application instrumentation and send the spans and App360 span metrics to Logz.io + +On deployment, your OpenTelemetry instrumentation captures spans from your application and forwards them to the collector, which exports the spans and App360 span metrics data to your Logz.io account. + +:::note +This integration uses OpenTelemetry Collector Contrib, not the OpenTelemetry Collector Core. +::: + + + + +## Set up your locally hosted OpenTelemetry installation to send spans and App360 span metrics to Logz.io + +**Before you begin, you'll need**: + +* An application instrumented with an OpenTelemetry instrumentation or any other supported instrumentations based on OpenTracing, Zipkin or Jaeger +* An active account with Logz.io +* A Logz.io metrics account + + +### Configure OpenTelemetry collector + +#### Get the collector + +You can either download the OpenTelemetry collector to your local host or run the collector as a Docker container. + +##### Download locally + +Create a dedicated directory on the host of your application and download the [OpenTelemetry collector](https://github.com/open-telemetry/opentelemetry-collector/releases/tag/cmd%2Fbuilder%2Fv0.73.0) that is relevant to the operating system of your host. + +##### Run as a Docker container + +:::note +If you are already running a Logz.io Docker image `logzio/otel-collector-traces`, the new image `logzio/otel-collector-spm` will replace it. +::: + +In the same Docker network as your application: + +```shell +docker pull otel/opentelemetry-collector-contrib:0.73.0 +``` + +:::note +This integration only works with a contrib image. +::: + +#### Create the config file + +After setting up the collector, create a configuration file `config.yaml` with the following parameters: + +```yaml +receivers: + otlp: + protocols: + grpc: + endpoint: "0.0.0.0:4317" + http: + endpoint: "0.0.0.0:4318" + +connectors: + spanmetrics: + aggregation_temporality: AGGREGATION_TEMPORALITY_CUMULATIVE + dimensions: + - name: rpc.grpc.status_code + - name: http.method + - name: http.status_code + - name: cloud.provider + - name: cloud.region + - name: db.system + - name: messaging.system + - default: DEV + name: env_id + dimensions_cache_size: 100000 + histogram: + explicit: + buckets: + - 2ms + - 8ms + - 50ms + - 100ms + - 200ms + - 500ms + - 1s + - 5s + - 10s + metrics_expiration: 5m + resource_metrics_key_attributes: + - service.name + - telemetry.sdk.language + - telemetry.sdk.name + +exporters: + logzio/traces: + account_token: <> + region: <> + prometheusremotewrite/spm: + endpoint: https://<>:8053 + add_metric_suffixes: false + headers: + Authorization: Bearer <> + +processors: + batch: + tail_sampling: + policies: + [ + { + name: policy-errors, + type: status_code, + status_code: {status_codes: [ERROR]} + }, + { + name: policy-slow, + type: latency, + latency: {threshold_ms: 1000} + }, + { + name: policy-random-ok, + type: probabilistic, + probabilistic: {sampling_percentage: 10} + } + ] + metricstransform/metrics-rename: + transforms: + - include: ^duration.*$$ + match_type: regexp + action: update + new_name: latency. + - include: calls + action: update + new_name: calls_total + metricstransform/labels-rename: + transforms: + - include: ^latency + action: update + match_type: regexp + operations: + - action: update_label + label: span.name + new_label: operation + - include: ^calls + action: update + match_type: regexp + operations: + - action: update_label + label: span.name + new_label: operation + +extensions: + pprof: + endpoint: :1777 + zpages: + endpoint: :55679 + health_check: + +service: + extensions: [health_check, pprof, zpages] + pipelines: + traces: + receivers: [otlp] + processors: [tail_sampling, batch] + exporters: [logzio/traces, spanmetrics] + metrics/spanmetrics: + receivers: [spanmetrics] + processors: [metricstransform/metrics-rename, metricstransform/labels-rename] + exporters: [prometheusremotewrite/spm] + telemetry: + logs: + level: "debug" +``` + +{@include: ../../_include/tracing-shipping/replace-tracing-token.html} + +{@include: ../../_include/tracing-shipping/replace-spm-token.html} + +{@include: ../../_include/log-shipping/listener-var.html} + +{@include: ../../_include/tracing-shipping/tail-sampling.md} + +If you already have an OpenTelemetry installation, add to the configuration file of your existing OpenTelemetry collector the parameters described in the next steps. + + + + +### Start the collector + +#### Locally running collector + +Run the following command: + +```shell +/otelcontribcol_ --config ./config.yaml +``` + +* Replace `` with the path to the directory where you downloaded the collector. +* Replace `` with the version name of the collector applicable to your system, e.g. `otelcontribcol_darwin_amd64`. + + + +#### Containerized collector + +Mount the `config.yaml` as volume to the `docker run` command and run it as follows. + +##### Linux + +``` +docker run \ +--network host \ +-v /config.yaml:/etc/otelcol-contrib/config.yaml \ +otel/opentelemetry-collector-contrib:0.73.0 + +``` + +Replace `` to the path to the `config.yaml` file on your system. + +##### Windows + +``` +docker run \ +-v /config.yaml:/etc/otelcol-contrib/config.yaml \ +-p 55678-55680:55678-55680 \ +-p 1777:1777 \ +-p 9411:9411 \ +-p 9943:9943 \ +-p 6831:6831 \ +-p 6832:6832 \ +-p 14250:14250 \ +-p 14268:14268 \ +-p 4317:4317 \ +-p 55681:55681 \ +otel/opentelemetry-collector-contrib:0.73.0 +``` + + +##### Optional parameters + +If required, you can add the following optional parameters as environment variables when running the container: + +| Parameter | Description | +|---|---| +| LATENCY_HISTOGRAM_BUCKETS | Comma separated list of durations defining the latency histogram buckets. Default: `2ms`, `8ms`, `50ms`, `100ms`, `200ms`, `500ms`, `1s`, `5s`, `10s` | +| SPAN_METRICS_DIMENSIONS | Each metric will have at least the following dimensions that are common across all spans: `Service name`, `Operation`, `Span kind`, `Status code`. The input is comma separated list of dimensions to add together with the default dimensions, for example: `region,http.url`. Each additional dimension is defined by a name from the span's collection of attributes or resource attributes. If the named attribute is missing in the span, this dimension will be omitted from the metric. | +| SPAN_METRICS_DIMENSIONS_CACHE_SIZE | The maximum items number of `metric_key_to_dimensions_cache`. Default: `10000`. | +| AGGREGATION_TEMPORALITY | Defines the aggregation temporality of the generated metrics. One of either `cumulative` or `delta`. Default: `cumulative`. | + + +### Run the application + +{@include: ../../_include/tracing-shipping/collector-run-note.md} + + +Run the application to generate traces. + + + +### Check Logz.io for your data + +Give your data some time to get from your system to ours, and then open [App360](https://app.logz.io/#/dashboard/spm/services/table?start=now-1h&end=now). + + diff --git a/docs/shipping/Other/App360.md b/docs/shipping/Other/App360.md deleted file mode 100644 index 8b560966..00000000 --- a/docs/shipping/Other/App360.md +++ /dev/null @@ -1,866 +0,0 @@ ---- -id: Service-Performance-Monitoring-App360 -title: Service Performance Monitoring via App360 -overview: This integration allows you to configure App360 Service Performance Monitoring with OpenTelemetry collector and send spans and span metrics from your OpenTelemetry installation to Logz.io. -product: ['tracing'] -os: ['windows', 'linux'] -filters: ['Other'] -logo: https://logzbucket.s3.eu-west-1.amazonaws.com/logz-docs/shipper-logos/span-metrics.png -logs_dashboards: [] -logs_alerts: [] -logs2metrics: [] -metrics_dashboards: ['40ZpsSfzfGhbguMYoxwOqm', '5PFq9YHx2iQkwVMLCMOmjJ'] -metrics_alerts: [] -drop_filter: [] ---- - - - -[App360](https://docs.logz.io/docs/user-guide/distributed-tracing/spm/) is a high-level monitoring dashboard within Logz.io that enables you to monitor your tracing services and operations. This integration allows you to configure Service Performance Monitoring with OpenTelemetry collector and send spans and span metrics from your OpenTelemetry installation to Logz.io. - -{@include: ../../_include/metric-shipping/custom-dashboard.html} Install the pre-built dashboard to enhance the observability of your metrics. - - - - - -{@include: ../../_include/metric-shipping/generic-dashboard.html} - - - -## Architecture overview - -This integration is based on OpenTelemetry. It works as an add-on to existing OpenTelemetry installations. If you need to set up OpenTelemetry first, refer to our documentation on [OpenTelemetry](https://app.logz.io/#/dashboard/integrations/OpenTelemetry-data). - -The integration includes: - -* Configuring the OpenTelemetry collector to receive spans generated by your application instrumentation and send the spans and span metrics to Logz.io - -On deployment, your OpenTelemetry instrumentation captures spans from your application and forwards them to the collector, which exports the spans and span metrics data to your Logz.io account. - -:::note -This integration uses OpenTelemetry Collector Contrib, not the OpenTelemetry Collector Core. -::: - - - - -## Set up your locally hosted OpenTelemetry installation to send spans and span metrics to Logz.io - -**Before you begin, you'll need**: - -* An application instrumented with an OpenTelemetry instrumentation or any other supported instrumentations based on OpenTracing, Zipkin or Jaeger -* Service Performance Monitoring dashboard [activated](https://docs.logz.io/docs/user-guide/distributed-tracing/setup-spm/#activate-the-service-performance-monitoring-dashboard) -* An active account with Logz.io -* A Logz.io span metrics account - - -### Download and configure OpenTelemetry collector - -Create a dedicated directory on the host of your application and download the [OpenTelemetry collector](https://github.com/open-telemetry/opentelemetry-collector/releases/tag/cmd%2Fbuilder%2Fv0.73.0) that is relevant to the operating system of your host. - -After downloading the collector, create a configuration file `config.yaml` with the following parameters: - -```yaml -receivers: - otlp: - protocols: - grpc: - endpoint: "0.0.0.0:4317" - http: - endpoint: "0.0.0.0:4318" - -connectors: - spanmetrics: - aggregation_temporality: AGGREGATION_TEMPORALITY_CUMULATIVE - dimensions: - - name: rpc.grpc.status_code - - name: http.method - - name: http.status_code - - name: cloud.provider - - name: cloud.region - - name: db.system - - name: messaging.system - - default: DEV - name: env_id - dimensions_cache_size: 100000 - histogram: - explicit: - buckets: - - 2ms - - 8ms - - 50ms - - 100ms - - 200ms - - 500ms - - 1s - - 5s - - 10s - metrics_expiration: 5m - resource_metrics_key_attributes: - - service.name - - telemetry.sdk.language - - telemetry.sdk.name - -exporters: - logzio/traces: - account_token: <> - region: <> - prometheusremotewrite/spm: - endpoint: https://<>:8053 - add_metric_suffixes: false - headers: - Authorization: Bearer <> - -processors: - batch: - tail_sampling: - policies: - [ - { - name: policy-errors, - type: status_code, - status_code: {status_codes: [ERROR]} - }, - { - name: policy-slow, - type: latency, - latency: {threshold_ms: 1000} - }, - { - name: policy-random-ok, - type: probabilistic, - probabilistic: {sampling_percentage: 10} - } - ] - metricstransform/metrics-rename: - transforms: - - include: ^duration.*$$ - match_type: regexp - action: update - new_name: latency. - - include: calls - action: update - new_name: calls_total - metricstransform/labels-rename: - transforms: - - include: ^latency - action: update - match_type: regexp - operations: - - action: update_label - label: span.name - new_label: operation - - include: ^calls - action: update - match_type: regexp - operations: - - action: update_label - label: span.name - new_label: operation - -extensions: - pprof: - endpoint: :1777 - zpages: - endpoint: :55679 - health_check: - -service: - extensions: [health_check, pprof, zpages] - pipelines: - traces: - receivers: [otlp] - processors: [tail_sampling, batch] - exporters: [logzio/traces, spanmetrics] - metrics/spanmetrics: - receivers: [spanmetrics] - processors: [metricstransform/metrics-rename, metricstransform/labels-rename] - exporters: [prometheusremotewrite/spm] - telemetry: - logs: - level: "debug" -``` - -{@include: ../../_include/tracing-shipping/replace-tracing-token.html} - -{@include: ../../_include/tracing-shipping/replace-spm-token.html} - -{@include: ../../_include/log-shipping/listener-var.html} - -{@include: ../../_include/tracing-shipping/tail-sampling.md} - -If you already have an OpenTelemetry installation, add to the configuration file of your existing OpenTelemetry collector the parameters described in the next steps. - - - - -### Start the collector - -Run the following command: - -```shell -/otelcontribcol_ --config ./config.yaml -``` - -* Replace `` with the path to the directory where you downloaded the collector. -* Replace `` with the version name of the collector applicable to your system, e.g. `otelcontribcol_darwin_amd64`. - -### Run the application - -Run the application to generate traces. - - -### Check Logz.io for your metrics - -Give your metrics some time to get from your system to ours, and then open [Tracing](https://app.logz.io/#/dashboard/jaeger). Navigate to the **Monitor** tab to view the span metrics. - - - -## Set up your OpenTelemetry installation using containerized collector to send spans and span metrics to Logz.io - -**Before you begin, you'll need**: - -* An application instrumented with an OpenTelemetry instrumentation or any other supported instrumentations based on OpenTracing, Zipkin or Jaeger -* Service Performance Monitoring dashboard [activated](https://docs.logz.io/docs/user-guide/distributed-tracing/setup-spm/#activate-the-service-performance-monitoring-dashboard) -* An active account with Logz.io -* A Logz.io span metrics account - -:::note -The span metrics account name should include your tracing account name. For example, if your tracing account name is "tracing", your metrics account could be named "tracing-metrics". -::: - - - -### Pull the Docker image for the OpenTelemetry collector - -:::note -If you are already running a Logz.io Docker image `logzio/otel-collector-traces`, the new image `logzio/otel-collector-spm` will replace it. -::: - -In the same Docker network as your application: - -```shell -docker pull otel/opentelemetry-collector-contrib:0.73.0 -``` - -:::note -This integration only works with a contrib image. -::: - -### Create a configuration file - -Create a file `config.yaml` with the following content: - -```yaml -receivers: - otlp: - protocols: - grpc: - endpoint: "0.0.0.0:4317" - http: - endpoint: "0.0.0.0:4318" - otlp/spanmetrics: - protocols: - grpc: - endpoint: :12345 - prometheus: - config: - global: - external_labels: - p8s_logzio_name: spm-otel - scrape_configs: - - job_name: 'spm' - scrape_interval: 15s - static_configs: - - targets: [ "0.0.0.0:8889" ] - -exporters: - logzio/traces: - account_token: <> - region: <> - prometheusremotewrite/spm: - endpoint: https://<>:8053 - headers: - Authorization: Bearer <> - prometheus: - endpoint: "localhost:8889" - logging: - -processors: - batch: - tail_sampling: - policies: - [ - { - name: policy-errors, - type: status_code, - status_code: {status_codes: [ERROR]} - }, - { - name: policy-slow, - type: latency, - latency: {threshold_ms: 1000} - }, - { - name: policy-random-ok, - type: probabilistic, - probabilistic: {sampling_percentage: 10} - } - ] - spanmetrics: - metrics_exporter: prometheus - latency_histogram_buckets: [2ms, 6ms, 10ms, 100ms, 250ms, 500ms, 1000ms, 10000ms, 100000ms, 1000000ms] - # Additional list of dimensions on top of: - # - service.name - # - operation - # - span.kind - # - status.code - dimensions: - # If the span is missing http.method, the processor will insert - # the http.method dimension with value 'GET'. - # For example, in the following scenario, http.method is not present in a span and so will be added as a dimension to the metric with value "GET": - # - promexample_calls{http_method="GET",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.method - default: GET - # If a default is not provided, the http.status_code dimension will be omitted - # if the span does not contain http.status_code. - # For example, consider a scenario with two spans, one span having http.status_code=200 and another missing http.status_code. Two metrics would result with this configuration, one with the http_status_code omitted and the other included: - # - promexample_calls{http_status_code="200",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - # - promexample_calls{operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.status_code - -extensions: - pprof: - endpoint: :1777 - zpages: - endpoint: :55679 - health_check: - -service: - extensions: [health_check, pprof, zpages] - pipelines: - traces: - receivers: [otlp] - processors: [spanmetrics,tail_sampling,batch] - exporters: [logzio/traces] - metrics/spanmetrics: - # This receiver is just a dummy and never used. - # Added to pass validation requiring at least one receiver in a pipeline. - receivers: [otlp/spanmetrics] - exporters: [prometheus] - metrics: - receivers: [prometheus] - exporters: [logging,prometheusremotewrite/spm] - telemetry: - logs: - level: "debug" - - -``` - -{@include: ../../_include/tracing-shipping/replace-tracing-token.html} - -{@include: ../../_include/tracing-shipping/replace-spm-token.html} - -{@include: ../../_include/log-shipping/listener-var.html} - -{@include: ../../_include/tracing-shipping/tail-sampling.md} - -If you already have an OpenTelemetry installation, add to the configuration file of your existing OpenTelemetry collector the parameters described in the next steps. - -### Add Logz.io exporter to your OpenTelemetry collector - -Add the following parameters to the configuration file of your OpenTelemetry collector: - -* Under the `receivers` list: - -```yaml - otlp/spanmetrics: - protocols: - grpc: - endpoint: :12345 - prometheus: - config: - global: - external_labels: - p8s_logzio_name: spm-otel - scrape_configs: - - job_name: 'spm' - scrape_interval: 15s - static_configs: - - targets: [ "0.0.0.0:8889" ] -``` - -* Under the `exporters` list: - -```yaml - logzio/traces: - account_token: <> - region: <> - prometheusremotewrite/spm: - endpoint: https://<>:8053 - headers: - Authorization: Bearer <> - prometheus: - endpoint: "localhost:8889" -``` - -* Under the `processors` list: - -```yaml - tail_sampling: - policies: - [ - { - name: policy-errors, - type: status_code, - status_code: {status_codes: [ERROR]} - }, - { - name: policy-slow, - type: latency, - latency: {threshold_ms: 1000} - }, - { - name: policy-random-ok, - type: probabilistic, - probabilistic: {sampling_percentage: 10} - } - ] - spanmetrics: - metrics_exporter: prometheus - latency_histogram_buckets: [2ms, 6ms, 10ms, 100ms, 250ms, 500ms, 1000ms, 10000ms, 100000ms, 1000000ms] - # Additional list of dimensions on top of: - # - service.name - # - operation - # - span.kind - # - status.code - dimensions: - # If the span is missing http.method, the processor will insert - # the http.method dimension with value 'GET'. - # For example, in the following scenario, http.method is not present in a span and so will be added as a dimension to the metric with value "GET": - # - promexample_calls{http_method="GET",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.method - default: GET - # If a default is not provided, the http.status_code dimension will be omitted - # if the span does not contain http.status_code. - # For example, consider a scenario with two spans, one span having http.status_code=200 and another missing http.status_code. Two metrics would result with this configuration, one with the http_status_code omitted and the other included: - # - promexample_calls{http_status_code="200",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - # - promexample_calls{operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.status_code -``` - -* Under the `service: pipelines` list: - -```yaml -pipelines: - traces: - receivers: [otlp] - processors: [spanmetrics,tail_sampling,batch] - exporters: [logzio/traces] - metrics/spanmetrics: - # This receiver is just a dummy and never used. - # Added to pass validation requiring at least one receiver in a pipeline. - receivers: [otlp/spanmetrics] - exporters: [prometheus] - metrics: - receivers: [prometheus] - exporters: [logging,prometheusremotewrite] -``` - - -{@include: ../../_include/tracing-shipping/replace-tracing-token.html} - -{@include: ../../_include/tracing-shipping/replace-spm-token.html} - -{@include: ../../_include/log-shipping/listener-var.html} - - -An example configuration file looks as follows: - -```yaml -receivers: - otlp: - protocols: - grpc: - endpoint: "0.0.0.0:4317" - http: - endpoint: "0.0.0.0:4318" - otlp/spanmetrics: - protocols: - grpc: - endpoint: :12345 - prometheus: - config: - global: - external_labels: - p8s_logzio_name: spm-otel - scrape_configs: - - job_name: 'spm' - scrape_interval: 15s - static_configs: - - targets: [ "0.0.0.0:8889" ] - -exporters: - logzio/traces: - account_token: <> - region: <> - prometheusremotewrite/spm: - endpoint: https://<>:8053 - headers: - Authorization: Bearer <> - prometheus: - endpoint: "localhost:8889" - logging: - -processors: - batch: - tail_sampling: - policies: - [ - { - name: policy-errors, - type: status_code, - status_code: {status_codes: [ERROR]} - }, - { - name: policy-slow, - type: latency, - latency: {threshold_ms: 1000} - }, - { - name: policy-random-ok, - type: probabilistic, - probabilistic: {sampling_percentage: 10} - } - ] - spanmetrics: - metrics_exporter: prometheus - latency_histogram_buckets: [2ms, 6ms, 10ms, 100ms, 250ms, 500ms, 1000ms, 10000ms, 100000ms, 1000000ms] - # Additional list of dimensions on top of: - # - service.name - # - operation - # - span.kind - # - status.code - dimensions: - # If the span is missing http.method, the processor will insert - # the http.method dimension with value 'GET'. - # For example, in the following scenario, http.method is not present in a span and so will be added as a dimension to the metric with value "GET": - # - promexample_calls{http_method="GET",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.method - default: GET - # If a default is not provided, the http.status_code dimension will be omitted - # if the span does not contain http.status_code. - # For example, consider a scenario with two spans, one span having http.status_code=200 and another missing http.status_code. Two metrics would result with this configuration, one with the http_status_code omitted and the other included: - # - promexample_calls{http_status_code="200",operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - # - promexample_calls{operation="/Address",service_name="shippingservice",span_kind="SPAN_KIND_SERVER",status_code="STATUS_CODE_UNSET"} 1 - - name: http.status_code - -extensions: - pprof: - endpoint: :1777 - zpages: - endpoint: :55679 - health_check: - -service: - extensions: [health_check, pprof, zpages] - pipelines: - traces: - receivers: [otlp] - processors: [spanmetrics,tail_sampling,batch] - exporters: [logzio/traces] - metrics/spanmetrics: - # This receiver is just a dummy and never used. - # Added to pass validation requiring at least one receiver in a pipeline. - receivers: [otlp/spanmetrics] - exporters: [prometheus] - metrics: - receivers: [prometheus] - exporters: [logging,prometheusremotewrite/spm] - telemetry: - logs: - level: "debug" - -``` - - -### Run the container - -Mount the `config.yaml` as volume to the `docker run` command and run it as follows. - -#### Linux - -``` -docker run \ ---network host \ --v /config.yaml:/etc/otelcol-contrib/config.yaml \ -otel/opentelemetry-collector-contrib:0.73.0 - -``` - -Replace `` to the path to the `config.yaml` file on your system. - -#### Windows - -``` -docker run \ --v /config.yaml:/etc/otelcol-contrib/config.yaml \ --p 55678-55680:55678-55680 \ --p 1777:1777 \ --p 9411:9411 \ --p 9943:9943 \ --p 6831:6831 \ --p 6832:6832 \ --p 14250:14250 \ --p 14268:14268 \ --p 4317:4317 \ --p 55681:55681 \ -otel/opentelemetry-collector-contrib:0.73.0 -``` - - -#### Optional parameters - -If required, you can add the following optional parameters as environment variables when running the container: - -| Parameter | Description | -|---|---| -| LATENCY_HISTOGRAM_BUCKETS | Comma separated list of durations defining the latency histogram buckets. Default: `2ms`, `8ms`, `50ms`, `100ms`, `200ms`, `500ms`, `1s`, `5s`, `10s` | -| SPAN_METRICS_DIMENSIONS | Each metric will have at least the following dimensions that are common across all spans: `Service name`, `Operation`, `Span kind`, `Status code`. The input is comma separated list of dimensions to add together with the default dimensions, for example: `region,http.url`. Each additional dimension is defined by a name from the span's collection of attributes or resource attributes. If the named attribute is missing in the span, this dimension will be omitted from the metric. | -| SPAN_METRICS_DIMENSIONS_CACHE_SIZE | The maximum items number of `metric_key_to_dimensions_cache`. Default: `10000`. | -| AGGREGATION_TEMPORALITY | Defines the aggregation temporality of the generated metrics. One of either `cumulative` or `delta`. Default: `cumulative`. | - - -### Run the application - -{@include: ../../_include/tracing-shipping/collector-run-note.md} - - -Run the application to generate traces. - - -### Check Logz.io for your metrics - -Give your metrics some time to get from your system to ours, and then open [Tracing](https://app.logz.io/#/dashboard/jaeger). Navigate to the **Monitor** tab to view the span metrics. - -## Kubernetes - -### Overview - -You can use a Helm chart to ship metrics and span metrics from your OpenTelemetry installation to Logz.io. The Helm tool is used to manage packages of preconfigured Kubernetes resources that use charts. - - -This Helm chart monitors the following metrics: - -* latency_bucket -* latency_sum -* lateny_count -* calls_total - -**Before you begin, you'll need**: - -* An application instrumented with an OpenTelemetry instrumentation or any other supported instrumentations based on OpenTracing, Zipkin or Jaeger -* Service Performance Monitoring dashboard [activated](https://docs.logz.io/docs/user-guide/distributed-tracing/setup-spm/#activate-the-service-performance-monitoring-dashboard) -* An active account with Logz.io - - -##### Deploy the Helm chart - -Add `logzio-helm` repo as follows: - -```shell -helm repo add logzio-helm https://logzio.github.io/logzio-helm -helm repo update -``` - -###### Default configuration (except AWS Fargate) - -```shell -helm install -n monitoring --create-namespace \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ ---set logzio-k8s-telemetry.spm.enabled=true \ ---set logzio-k8s-telemetry.secrets.env_id="<>" \ ---set logzio-k8s-telemetry.secrets.SpmToken="<>" \ ---set logzio-k8s-telemetry.serviceGraph.enabled=true \ ---set deployEvents.enabled=true \ ---set logzio-k8s-events.secrets.logzioShippingToken="<>" \ ---set logzio-k8s-events.secrets.logzioListener="<>" \ ---set logzio-k8s-events.secrets.env_id="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | Your [span metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | - -###### AWS Fargate configuration - - -To ship logs from pods running on Fargate, set the `fargateLogRouter.enabled` value to `true`. Doing so will deploy a dedicated `aws-observability` namespace and a `configmap` for the Fargate log router. For more information on EKS Fargate logging, please refer to the [official AWS documentation](https://docs.aws.amazon.com/eks/latest/userguide/fargate-logging.html). - -```shell -helm install -n monitoring \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ ---set logzio-k8s-telemetry.spm.enabled=true \ ---set logzio-k8s-telemetry.secrets.env_id="<>" \ ---set logzio-k8s-telemetry.secrets.SpmToken="<>" \ ---set logzio-k8s-telemetry.serviceGraph.enabled=true \ ---set deployEvents.enabled=true \ ---set logzio-k8s-events.secrets.logzioShippingToken="<>" \ ---set logzio-k8s-events.secrets.logzioListener="<>" \ ---set logzio-k8s-events.secrets.env_id="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | Your [span metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | - - - - -##### Check Logz.io for your traces - -Give your traces some time to get from your system to ours, then open [Logz.io](https://app.logz.io/). - - -#### Customizing Helm chart parameters - -##### Configure customization options - -You can use the following options to update the Helm chart parameters: - -* Specify parameters using the `--set key=value[,key=value]` argument to `helm install`. - -* Edit the `values.yaml`. - -* Overide default values with your own `my_values.yaml` and apply it in the `helm install` command. - - -If required, you can add the following optional parameters as environment variables: - -| Parameter | Description | -|---|---| -| config.processors.spanmetrics.latency_histogram_buckets | Comma separated list of durations defining the latency histogram buckets. Default: `2ms`, `8ms`, `50ms`, `100ms`, `200ms`, `500ms`, `1s`, `5s`, `10s` | -| config.processors.spanmetrics.dimensions | Each metric will have at least the following dimensions that are common across all spans: `Service name`, `Operation`, `Span kind`, `Status code`. The input is comma separated list of dimensions to add together with the default dimensions, for example: `region,http.url`. Each additional dimension is defined by a name from the span's collection of attributes or resource attributes. If the named attribute is missing in the span, this dimension will be omitted from the metric. | -| config.processors.spanmetrics.dimensions_cache_size | The maximum items number of `metric_key_to_dimensions_cache`. Default: `10000`. | -| config.processors.spanmetrics.aggregation_temporality | Defines the aggregation temporality of the generated metrics. One of either `cumulative` or `delta`. Default: `cumulative`. | -| secrets.SamplingLatency | Threshold for the spand latency - all traces slower than the threshold value will be filtered in. Default 500. | -| secrets.SamplingProbability | Sampling percentage for the probabilistic policy. Default 10. | - -###### Example - -You can run the chart with your custom configuration file that takes precedence over the `values.yaml` of the chart. - -For example: - -:::note -The collector will sample **ALL traces** where is some span with error with this example configuration. -::: - -```yaml -baseCollectorConfig: - processors: - tail_sampling: - policies: - [ - { - name: error-in-policy, - type: status_code, - status_code: {status_codes: [ERROR]} - }, - { - name: slow-traces-policy, - type: latency, - latency: {threshold_ms: 400} - }, - { - name: health-traces, - type: and, - and: { - and_sub_policy: - [ - { - name: ping-operation, - type: string_attribute, - string_attribute: { key: http.url, values: [ /health ] } - }, - { - name: main-service, - type: string_attribute, - string_attribute: { key: service.name, values: [ main-service ] } - }, - { - name: probability-policy-1, - type: probabilistic, - probabilistic: {sampling_percentage: 1} - } - ] - } - }, - { - name: probability-policy, - type: probabilistic, - probabilistic: {sampling_percentage: 20} - } - ] -``` - -``` -helm install -f /my_values.yaml \ ---set logzio.region=<> \ ---set logzio.tracing_token=<> \ ---set logzio.metrics_token=<> \ ---set traces.enabled=true \ ---set spm.enabled=true \ -logzio-k8s-telemetry logzio-helm/logzio-k8s-telemetry -``` - -Replace `` with the path to your custom `values.yaml` file. - -{@include: ../../_include/tracing-shipping/replace-tracing-token.html} - -{@include: ../../_include/tracing-shipping/replace-spm-token.html} - - - - -#### Uninstalling the Chart - -The uninstall command is used to remove all the Kubernetes components associated with the chart and to delete the release. - -To uninstall the `logzio-k8s-telemetry` deployment, use the following command: - -```shell -helm uninstall logzio-k8s-telemetry -```