Skip to content

Latest commit

 

History

History
85 lines (62 loc) · 8.42 KB

README.md

File metadata and controls

85 lines (62 loc) · 8.42 KB

Opentelemetry Collector For Api Discovery

This document describes the set up details for the OpenTelemetry Collector For Api Discovery based on different datasource types.

Pre-req: Ensure one of the below datasource type is available on your system to collect traces through the opentelemetry collector

Example configurations for both Istio and nginx are provided here

  1. Istio installation details - Istio-Readme.md
  2. nginx Conguration details - Nginx-Readme.md

Pre-req: Ensure helm is installed

See here for details
https://helm.sh/docs/intro/install/

Use the Helm chart to deploy the collector.

In the helm directory, update the values.yaml file based on your apiconnect provider org, authentication and istio set up

The following parameters require updates:

  • discovery.datasource_type - (Optional) field to set the datasource type to decide if the specific telemetry or envoyfilter configuration is needed. If the datasource type is istio, the required Istio Telemetry CR or Istio Envoy filter CR will be installed.
  • discovery.datasource_name - (Optional) field to set the datasource name for all APIs discovered by the collector. If datasource name is empty, the namespace of the collected API will be used.
  • discovery.apic_host_domain - Domain name of the ApiConnect instance where discovered APIs will be sent.
      Example : us-east-a.apiconnect.automation.ibm.com
  • discovery.provider_org - The provider org name of the apiconnect manager
  • discovery.apikey - An API Key can be obtained from the api-manager for the user who has access to post the API. An API key can be created by logging into the APIC Manager UI and selecting the "My API Keys" option under the profile icon from the top navigation bar. The apikey will be added to a kubernetes secret as part of the deployment and then mounted on the collector deployment pod.
  • discovery.processor - The flag to enable or disable the processors. The configmap enables the existing batch and memory_limiter processor when enabled value is set and will not provide any processors in other cases. If you attempt to send a trace with more than 11000 spans at a time the collector will reject the payload and you will be required to turn on the batch processor. The available batch and memory limiter processors are configurable according to the base systems requirements. The limit_mib in the memory_limter processor can be increased if you update the resource limits of the collector deployment.
      For Reference: Batch processor and Memory Limiter processor
    • Keeping the attributes/ibm-apiconnect,redaction/ibm-apiconnect,filter/ibm-apiconnect,transform/ibm-apiconnect,resource/ibm-apiconnect in the service.pipelines.traces.processors in the same order while enabling processors is required, as we have built-in processors that enhance the collector's performance. If you neglect to include the processors it will degrade the quality of the collected traffic as well as the performance of the collector. It may not set the data source name for all APIs discovered by the collector.
    • Since the filter, resource and attributes processors are supported, you can configure these processors to customize the traffic along with the existing processors in the pipelines.
        Example service pipelines value: processors: [attributes/ibm-apiconnect,redaction/ibm-apiconnect,filter/ibm-apiconnect,transform/ibm-apiconnect,resource/ibm-apiconnect,batch,memory_limiter,filter,resource,attributes]
        For Reference: Filter processor, Resource processor, Attributes processor, Transform processor, Redaction processor
  • namespace: The namespace where istio or nginx has been deployed on your cluster. As required by istio's telemetry integration the collector pod will be deployed here.
  • images.api_discovery_collector: As new versions of the collectors are released updating this property will enable the upgrade of the collector deployment. Note: collectors will require updates to ensure they remain compatible with the discovery service. Details of these updates will be available in this repository.
  • logging.log_level: Default log_level is info. For debug purposes the log level can be increased to debug if needed.
  • logging.debugexporter_verbosity: The default value is basic. For detailed information about the exporter, the verbosity can be increased to detailed if needed.
    Note: It is recommended to keep the verbosity as basic for the collector with a large amount of traffic flowing through it.

Istio specific parameters

  • collector_mode: (Optional) Istio can be installed either as Istio telemetry or Istio Envoyfilter. By default the values file sets this to telemetry and telemetry CR telemtry.yaml will be installed. The collector mode can be set to envoyfilter in values.yaml, then the Envoy filter EnvoyFilter.yaml will be installed in the istio-system namespace.
  • telemetry_namespace: (Optional) This is where the istio Telemetry CR will be deployed. By default the values file sets this to istio-system as the root configuration namespace to provide mesh level collection configuration. This can be customized as you wish based on your collection requirements regarding the deployed applications you want to be discovered. See here for further details https://istio.io/latest/docs/reference/config/telemetry/. Not needed for nginx configuration.
    • For example: If there are more APIs discovered and you want to restrict some of the services, then the telemetry CR can be configured with matchLabels selector as mentioned in one of the examples

Once you have made the required updates to the values.yaml file you can deploy the collector.

Run the following command to deploy the collector

helm template . | kubectl apply -f -

Output should be as follows which indicate that the required Kubernetes Reources have been deployed where telemetry creation is only for Istio

helm template . | kubectl apply -f -
secret/api-discovery-secret created
service/management-api-discovery-otel-collector created
deployment.apps/management-api-discovery-otel-collector created
telemetry.telemetry.istio.io/api-discovery-otel created

Once the collector has been deployed any istio or nginx instructmented pods which have traffic running through them will begin to be discovered and sent to the apiconnect discovery service.

Upgrading the collector

The upgrade of the otel collector mainly refers to the changes in the values.yaml, especially with the images.api_discovery_collector parameter.

The changes may include introducing a new parameter, changing existing parameters

It is recommended to upgrade the collector from time to time.

Make sure values.yaml file is based on your apiconnect provider org, authentication and datasource are set up.

Run the following command to upgrade the collector with the new changes

helm template . | kubectl apply -f -

Uninstalling the collector

The collector can be uninstalled using the following comman.

helm template . | kubectl delete -f -