jcchavezs/zipkin-opentracing
A Zipkin bridge with OpenTracing
Maintainers
Fund package maintenance!
Requires
- php: >=7.4 || ^8.0
- opentracing/opentracing: ^1.0.1
- openzipkin/zipkin: ^3.0.0
Requires (Dev)
- phpspec/prophecy-phpunit: ^2.0
- phpstan/phpstan: ^0.12.26
- phpunit/phpunit: ^9.0
- squizlabs/php_codesniffer: 3.*
Suggests
None
Provides
- opentracing/opentracing: 1.0.0
Conflicts
None
Replaces
None
MIT 6bd908f84ff611dff4d64c5e7d510bd6a1107575
- JosΓ© Carlos ChΓ‘vez <jcchavezs.woop@gmail.com>
This package is auto-updated.
Last update: 2026-06-29 01:41:14 UTC
README
π Travis CI
π OpenTracing Badge
π Total Downloads
π Minimum PHP Version
π License
Zipkin implementation for OpenTracingTracer in PHP.
This library allows OpenTracing API consumers to use Zipkin as their tracing backend. For details on how to work with spans and traces we suggest looking at the documentation and README from the OpenTracing API.
Getting started
Required Reading
In order to understand OpenTracing API, one must first be familiar with the OpenTracing project and terminology more generally.
To understand how Zipkin works, you can look at Zipkin Architecture and Zipkin PHP documentation.
Installation
composer require jcchavezs/zipkin-opentracing
Usage
Firstly, we need to setup a tracer:
use OpenTracing\GlobalTracer; use Psr\Log\NullLogger; use Zipkin\Endpoint; use Zipkin\Samplers\BinarySampler; use Zipkin\TracingBuilder; use Zipkin\Reporters\Http; $endpoint = Endpoint::create('my_service', '127.0.0.1', null, 8081); $reporter = new Zipkin\Reporters\Http(); $sampler = BinarySampler::createAsAlwaysSample(); $tracing = TracingBuilder::create() ->havingLocalEndpoint($endpoint) ->havingSampler($sampler) ->havingReporter($reporter) ->build(); $zipkinTracer = new ZipkinOpenTracing\Tracer($tracing); GlobalTracer::set($zipkinTracer); // optional
Creating Spans
- Starting a root span
- Starting a span for a given request
- Active span and scope manager
- Using span options
Propagation of context
Flushing Spans to the agent
PHP as a request scoped language has no simple means to pass the collected spans data to a background process without
blocking the main request thread/process. It is mandatory to execute the Tracer::flush() after the response is served
to the client by using register_shutdown_function.
use OpenTracing\GlobalTracer; $application->run(); register_shutdown_function(function() { GlobalTracer::get()->flush(); });
Contribution
Run tests
composer test
Fix lint
composer fix-lint
