easyops-cn/easykin

A simple zipkin implementation for php.

0.3.6 2022-11-14 08:36 UTC

README

Software License Build Status

这是一个简单的Zipkin PHP库,根据 官方概念文档 实现,主要用于PHP实现的web服务链路追踪,并针对B3 Propagation封装了专用的Trace类,方便Http服务的接入。

Quick Start

初始化

定义服务基础信息:

EasyKin::setEndpoint(
	'My service', // 服务名
	'127.0.0.1', // 服务IP
	80); // 服务端口

定义trace信息上报方式,提供FileLogger和HttpLogger两种方式,可以基于Logger接口实现更多上报方式:

EasyKin::setLogger(
	new easyops\easykin\logger\HttpLogger(
		'http://127.0.0.1:9411/api/v1/spans', false));

初始化Trace

对于前端(链路的源头):

EasyKin::setTrace(new \easyops\easykin\core\Trace('get:/login'));

对于后端,需要提取请求Header中的B3信息:

$traceId = !empty($_SERVER['HTTP_X_B3_TRACEID']) ? $_SERVER['HTTP_X_B3_TRACEID']) : null;
$parentSpanId = !empty($_SERVER['HTTP_X_B3_PARENTSPANID']) ? $_SERVER['HTTP_X_B3_PARENTSPANID'] : null;
$spanId = !empty($_SERVER['HTTP_X_B3_SPANID']) ? $_SERVER['HTTP_X_B3_SPANID'] : null;
$isSampled = !empty($_SERVER['HTTP_X_B3_SAMPLED'])) ? $_SERVER['HTTP_X_B3_SAMPLED'] : null;

EasyKin::setTrace(new \easyops\easykin\core\Trace('get:/login', $sampled, $traceId, $parentSpanId, $spanId));

也可以使用封装好的HttpTrace类,前后端调用方式都一致:

EasyKin::setTrace(new \easyops\easykin\core\HttpTrace());

以上动作均需在你的服务程序入口处尽早完成,在程序结尾处执行上报方法:

EasyKin::trace();

注意:如果服务程序因为异常而中断,EasyKin依然会上报trace信息

新建一个Span

当你的服务发起请求时,需要新建一个Span来承载该请求的信息:

$span = EasyKin::newSpan(
	'get:/users', // span名字,这里以请求url作为名字
	'users service',  // 请求的服务名
	'127.0.0.1',      // 请求的服务IP
	8080);            // 请求的服务端口

然后执行你的请求逻辑。当请求结果返回后,应尽快执行:

$span->receive();

以便准确记录该请求的结束时间。

执行上报

当服务应用程序处理完一次请求后,需要执行上报动作:

EasyKin::trace();