yuslf / jaeger-php
jaeger的php客户端
v2.0.5-beta2
2019-05-24 08:16 UTC
Requires
- php: >=5.6.0
- opentracing/opentracing: 1.0.0-beta2
- packaged/thrift: 0.10.0
This package is not auto-updated.
Last update: 2024-09-21 10:57:56 UTC
README
分布式追踪原理
安装
通过composer安装
编辑composer.json
{
"minimum-stability": "dev",
"require": {
"jukylin/jaeger-php" : "^2.0",
"opentracing/opentracing":"1.0.0-beta2"
}
}
composer update
初始化Jaeger-php
$config = Config::getInstance();
$tracer = $config->initTrace('example', '0.0.0.0:6831');
128位
$config->gen128bit();
从全局变量中提取
$spanContext = $tracer->extract(Formats\TEXT_MAP, $_SERVER);
开始Span
$serverSpan = $tracer->startSpan('example HTTP', ['child_of' => $spanContext]);
分布式上下文传播
$serverSpan->addBaggageItem("version", "2.0.0");
注入到全局变量中
$clientTrace->inject($clientSapn1->spanContext, Formats\TEXT_MAP, $_SERVER);
标签和日志
//can search in Jaeger UI
$span->addTags(['http.status' => "200"]);
//log record
$span->log(['error' => "HTTP request timeout"]);
关闭追踪
$config->setDisabled(true);
Zipkin B3传播
不支持
128位
和分布式上下文传播
$config::$propagator = \Jaeger\Constants\PROPAGATOR_ZIPKIN;
完成Span并刷新追踪
$span->finish();
$config->flush();
更多示例
特性
-
传输方式
- 通过UDP上的Thrift
-
采样
- 常量采样器
- 概率采样器