drefined / php-zipkin
Zipkin 的 PHP 跟踪库
dev-master
2017-02-22 23:47 UTC
Requires
- php: ^7.0
- guzzlehttp/guzzle: ^6.2
Requires (Dev)
- laravel/framework: 5.3.*
- phpunit/phpunit: ^5.7.0
This package is not auto-updated.
Last update: 2024-09-28 19:31:19 UTC
README
这是一个为 OpenZipkin 提供的非官方 PHP 库。
状态
不完整,只有一个传输方式且没有集成。此库仅包含用于向 Zipkin 发送跨度的一个非常简化的实现。
入门
推荐通过 Composer 安装 PHP-Zipkin。
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)] );
Laravel 集成(简单)
在适当的位置添加中间件和服务提供者。
<?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, ], ... ];
待办事项
- 添加完整的 Laravel 集成(目前支持无应用环境配置的简单实现)
- 添加 Symfony 集成
- 添加 Redis 包装器
- 添加 HTTP 包装器
- 添加 PDO 包装器
- 添加 Scribe 传输
- 添加 Kafka 传输
灵感来源
参考
生成 PHP thrift 类
- ls thrift/ | xargs -I {} thrift --gen php thrift/{}
许可证
贡献者
- David Phruksukarn