Skip to main content

Cisco Distribution for OpenTelemetry

Project description

otel-py

PIP Published Version Apache License Coverage

Trace

This package provides OpenTelemetry-compliant tracing to Python applications for the collection of distributed tracing and performance metrics in Cisco Telescope.

Contents

Installation

Requirements

Python >=3.8, <4.0 pip3 >= 22.0

Install packages

To install Cisco OpenTelemetry Distribution simply run:

pip install cisco-telescope

Full instrumentation support

To install the required dependencies for all relevant supported instrumentation frameworks run:

telescope-bootstrap

Library initialization

Cisco OpenTelemetry Distribution is activated and instruments the supported libraries once the tracing.init() has returned.

To initialize the library, you'll need a cisco-token, which is taken from your Account tab on the Telescope console Settings page.

from cisco_telescope import tracing

tracing.init(
  service_name="<your-service-name>",
  cisco_token="<your-cisco-token>"
)

OpenTelemetry Collector Configuration

By default, Cisco OpenTelemetry Distribution exports data directly to Cisco Telescope's infrastructure backend. Existing OpenTelemetery Collector is supported, the following configuration can be applied

Configure custom trace exporter

Cisco OpenTelemetry Distribution supports the configuration of multiple custom exporters. Note that you will need to handle your exporter authorization. Example for creating OtlpGrpc Span exporter to local OpenTelemetry collector:

from cisco_telescope import tracing, options

tracing.init(
  service_name="<your-service-name>",
  exporters=[
    options.ExporterOptions(
      exporter_type="otlp-grpc",
      collector_endpoint="grpc://localhost:4317"
    ),
  ]
)

Configure custom OpenTelemetry collector to export trace data to Cisco Telescope's external collector.

collector.yaml ...

exporters:
  otlphttp:
    traces_endpoint: https://production.cisco-udp.com/trace-collector
    headers:
      authorization: Bearer <Your Telescope Token>
    compression: gzip


service:
  pipelines:
    traces:
      exporters: [otlphttp]

Existing OpenTelemetry Instrumentation

Notice: Only relevant if interested in streaming existing OpenTelemetry workloads. Cisco Telescope. supports native OpenTelemetery traces.

from opentelemetry import trace
from opentelemetry.sdk.resources import Resource
from opentelemetry.sdk.trace import TracerProvider
from opentelemetry.sdk.trace.export import BatchSpanProcessor

from opentelemetry.exporter.otlp.proto.http.trace_exporter import (
    OTLPSpanExporter as OTLPHTTPExporter,
)

provider = TracerProvider(resource=Resource.create())
trace.set_tracer_provider(provider)

http_exporter = OTLPHTTPExporter(
  endpoint="https://production.cisco-udp.com/trace-collector",
  headers= {
    "authorization": "Bearer <Your Telescope Token>",
  },
)

processor = BatchSpanProcessor(http_exporter)
provider.add_span_processor(processor)

Supported Runtimes

Cisco OpenTelemetry Distribution supports Python 3.6+

Supported Libraries

Cisco OpenTelemetry Python Distribution is extending Native OpenTelemetry, supported libraries available here.

Cisco OpenTelemetry Python Distribution provides out-of-the-box instrumentation (tracing) and advanced payload collections for many popular frameworks and libraries.

Library Extended Support Version
requests Fully supported
aiohttp Fully supported
grpc Client/Server Unary support

Configuration

Advanced options can be configured as a parameter to the init() method:

Parameter Env Type Default Description
cisco_token CISCO_TOKEN string - Cisco account token
service_name OTEL_SERVICE_NAME string application Application name that will be set for traces
debug CISCO_DEBUG string False Debug logs
payloads_enabled CISCO_PAYLOADS_ENABLED string True Debug logs

Exporter options

Parameter Env Type Default Description
collector_endpoint OTEL_COLLECTOR_ENDPOINT string https://production.cisco-udp.com/trace-collector The address of the trace collector to send traces to
type OTEL_EXPORTER_TYPE string otlp-http The exporter type to use (Currently only otlp-http is supported). Multiple exporter option available via init function see example below

Getting Help

If you have any issue around using the library or the product, please don't hesitate to:

  • Use the documentation.
  • Use the help widget inside the product.
  • Open an issue in GitHub.

License

Provided under the Apache 2.0. See LICENSE for details.

Copyright 2022, Cisco

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cisco-telescope-1.3.2.tar.gz (20.0 kB view details)

Uploaded Source

Built Distribution

cisco_telescope-1.3.2-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file cisco-telescope-1.3.2.tar.gz.

File metadata

  • Download URL: cisco-telescope-1.3.2.tar.gz
  • Upload date:
  • Size: 20.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/35.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.11.4 keyring/23.5.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.13

File hashes

Hashes for cisco-telescope-1.3.2.tar.gz
Algorithm Hash digest
SHA256 157ff827d492525d3c4e2dab90041933e018f24919452e4182f4a5a259e27440
MD5 a461d51b6cfe335d7f1ce23c3e524eb0
BLAKE2b-256 e4c8aa264a309048b0acbca7e69708b44a5436d5976ec5d242b2400b7f4f890e

See more details on using hashes here.

File details

Details for the file cisco_telescope-1.3.2-py3-none-any.whl.

File metadata

  • Download URL: cisco_telescope-1.3.2-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/35.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.11.4 keyring/23.5.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.13

File hashes

Hashes for cisco_telescope-1.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9a331cf6399486305c9eb2809a5f6c030a4d092cc6ebc14f73bce6323f18caf4
MD5 298ea6490d3483d4cd98c403757cb9e0
BLAKE2b-256 093afe5e7e74b0312db11611d01d4aa32a386289e7a1c1b6e94d15e193e41df6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page