yuslf/jaeger-php

jaeger的php客户端

v2.0.5-beta2 2019-05-24 08:16 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
  • 采样

    • 常量采样器
    • 概率采样器

参考

OpenTracing

Jaeger