sablesoft/jaeger-php

jaeger的php客户端


README

Build Status Minimum PHP Version License Coverage Status

jaeger-php

分布式追踪原理

安装

通过composer安装

编辑composer.json文件

{
  "minimum-stability": "dev",
  "require":           {
    "jukylin/jaeger-php" : "^2.0",
    "opentracing/opentracing":"1.0.0-beta5"
  }
}

执行composer update

初始化Jaeger-php

$config = Config::getInstance();
$tracer = $config->initTracer('example', '0.0.0.0:6831');

128位

$config->gen128bit();

从Superglobals提取

$spanContext = $tracer->extract(Formats\TEXT_MAP, $_SERVER);

启动Span

$serverSpan = $tracer->startSpan('example HTTP', ['child_of' => $spanContext]);

分布式上下文传递

$serverSpan->addBaggageItem("version", "2.0.0");

注入到Superglobals

$clientTrace->inject($clientSapn1->spanContext, Formats\TEXT_MAP, $_SERVER);

标签和日志

//can search in Jaeger UI
$span->setTag('http.status', "200");

//log record
$span->log(['error' => "HTTP request timeout"]);

关闭Tracer

$config->setDisabled(true);

Zipkin B3传递

不支持分布式上下文传递

$config::$propagator = \Jaeger\Constants\PROPAGATOR_ZIPKIN;

完成Span并刷新Tracer

$span->finish();
$config->flush();

更多示例

功能

  • 传输

    • 通过UDP上的Thrift
  • 采样

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

参考

OpenTracing

Jaeger