Download the PHP package open-telemetry/opentelemetry-auto-curl without Composer
On this page you can find all versions of the php package open-telemetry/opentelemetry-auto-curl. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download open-telemetry/opentelemetry-auto-curl
More information about open-telemetry/opentelemetry-auto-curl
Files in open-telemetry/opentelemetry-auto-curl
Package opentelemetry-auto-curl
Short Description OpenTelemetry auto-instrumentation for curl
License Apache-2.0
Homepage https://opentelemetry.io/docs/php
Informations about the package opentelemetry-auto-curl
This is a read-only subtree split of https://github.com/open-telemetry/opentelemetry-php-contrib.
OpenTelemetry curl auto-instrumentation
Please read https://opentelemetry.io/docs/instrumentation/php/automatic/ for instructions on how to install and configure the extension and SDK.
Overview
Auto-instrumentation hooks are registered via composer, and client kind spans will automatically be created when calling curl_exec
or curl_multi_exec
functions.
Additionally, distributed tracing is supported by setting the traceparent
header.
Limitations
The curl_multi instrumentation is not resilient to shortcomings in the application and requires proper implementation. If the application does not call the curl_multi_info_read function, the instrumentation will be unable to measure the execution time for individual requests-time will be aggregated for all transfers. Similarly, error detection will be impacted, as the error code information will be missing in this case. In case of encountered issues, it is recommended to review the application code and adjust it to match example #1 provided in curl_multi_exec documentation.
To ensure the stability of the monitored application, capturing request headers sent to the server works only if the application does not use the CURLOPT_VERBOSE
option.
Configuration
Disabling curl instrumentation
The extension can be disabled via runtime configuration:
Request and response headers capturing
Curl auto-instrumentation enables capturing headers from both requests and responses. This feature is disabled by default and be enabled through environment variables or array directives in the php.ini
configuration file.
To enable response header capture from the server, specify the required headers as shown in the example below. In this case, the "Content-Type" and "Server" headers will be captured. These options values are case-insensitive:
Environment variables configuration
php.ini configuration
Similarly, to capture headers sent in a request to the server, use the following configuration:
All versions of opentelemetry-auto-curl with dependencies
ext-curl Version *
ext-opentelemetry Version *
open-telemetry/api Version ^1.0
open-telemetry/sem-conv Version ^1.24