dev-master
9999999-dev https://github.com/drefined/php-zipkinZipkin's PHP tracer library
MIT
The Requires
- php ^7.0
- guzzlehttp/guzzle ^6.2
The Development Requires
by David Phruksukarn
php tracer zipkin tracing
Zipkin's PHP tracer library
This is an unofficial PHP library for OpenZipkin., (*1)
Incomplete, only has one transport with zero integrations. This library contains a very minimal implementation for just sending spans to zipkin., (*2)
The recommended way to install PHP-Zipkin is through Composer, (*3)
composer require drefined/php-zipkin
<?php $client = new \GuzzleHttp\Client(); $logger = new \Drefined\Zipkin\Transport\HTTPLogger($client); $tracer = new \Drefined\Zipkin\Tracer($logger, 1.0, true); $endpoint = new \Drefined\Zipkin\Core\Endpoint('127.0.0.1', 8080, 'test-trace'); $trace = new \Drefined\Zipkin\Core\Trace($tracer, $endpoint); $trace->createNewSpan('test-server-trace'); $trace->record( [Annotation::generateServerRecv()], [BinaryAnnotation::generateString('server.request.uri', '/server')] ); $trace->record( [Annotation::generateServerSend()], [BinaryAnnotation::generateString('server.response', 200)] );
Add middleware and service provider in proper locations., (*4)
<?php // laravel-project/app/Http/Kernel.php namespace App\Http; use ... use Drefined\Zipkin\Instrumentation\Laravel\Middleware\EnableZipkinTracing; class Kernel extends HttpKernel { ... protected $middleware = [ ... EnableZipkinTracing::class, ]; ... }
<?php // laravel-project/config/app.php use Drefined\Zipkin\Instrumentation\Laravel\Providers\ZipkinTracingServiceProvider; return [ ... 'providers' => [ ... ZipkinTracingServiceProvider::class, ], ... ];
Zipkin's PHP tracer library
MIT
php tracer zipkin tracing