Skip to main content

Falcon instrumentation for OpenTelemetry

Project description

pypi

This library builds on the OpenTelemetry WSGI middleware to track web requests in Falcon applications.

Installation

pip install opentelemetry-instrumentation-falcon

Configuration

Exclude lists

To exclude certain URLs from being tracked, set the environment variable OTEL_PYTHON_FALCON_EXCLUDED_URLS (or OTEL_PYTHON_EXCLUDED_URLS as fallback) with comma delimited regexes representing which URLs to exclude.

For example,

export OTEL_PYTHON_FALCON_EXCLUDED_URLS="client/.*/info,healthcheck"

will exclude requests such as https://site/client/123/info and https://site/xyz/healthcheck.

Request attributes

To extract certain attributes from Falcon’s request object and use them as span attributes, set the environment variable OTEL_PYTHON_FALCON_TRACED_REQUEST_ATTRS to a comma delimited list of request attribute names.

For example,

export OTEL_PYTHON_FALCON_TRACED_REQUEST_ATTRS='query_string,uri_template'

will extract path_info and content_type attributes from every traced request and add them as span attritbues.

Falcon Request object reference: https://falcon.readthedocs.io/en/stable/api/request_and_response.html#id1

Request/Response hooks

The instrumentation supports specifying request and response hooks. These are functions that get called back by the instrumentation right after a Span is created for a request and right before the span is finished while processing a response. The hooks can be configured as follows:

def request_hook(span, req):
    pass

def response_hook(span, req, resp):
    pass

FalconInstrumentation().instrument(request_hook=request_hook, response_hook=response_hook)

References

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

Built Distribution

File details

Details for the file opentelemetry_instrumentation_falcon-0.49b2.tar.gz.

File metadata

File hashes

Hashes for opentelemetry_instrumentation_falcon-0.49b2.tar.gz
Algorithm Hash digest
SHA256 dcf4e69cbe1710996ea3c325ea0fce74826a9fc098b734a8c603fae746b0a248
MD5 7900024f6829c0a1f466ab6ef1823a0a
BLAKE2b-256 77753a0863b9fe1ab253246d6eea44fb9e56befcdc6f3dae56482684d9af7da3

See more details on using hashes here.

File details

Details for the file opentelemetry_instrumentation_falcon-0.49b2-py3-none-any.whl.

File metadata

File hashes

Hashes for opentelemetry_instrumentation_falcon-0.49b2-py3-none-any.whl
Algorithm Hash digest
SHA256 71bf97767e35d4bce890194f22a2b5992b234af2fd7a07d6794ab421b9cf6190
MD5 fae17a5cfa1d40ff9b8838ca14b429ca
BLAKE2b-256 ebf0a5d64aeb735f18b4489d3e46b62aa6f7c3dce84618d980c272e5d264fdd9

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