webman的链路追踪组件,基于xiaoyangguang/aop, 实现了基本的链路追踪组件, 比如mysql es redis 开发者可自定义追踪方法函数,实现自己需要追踪的组件,可追踪composer加载的三方库,比如thinkorm的数据库执行函数 (可选择自定义收集追踪上报数据类,并配置在tracer.php中 如果example无法满足你的需求)
composer require xiaoyangguang/tracer
配置 config\plugin\xiaoyangguang\tracer\tracer.php文件
<?php
//区分大小写 不能照搬需要追踪自定义组件照着example写很简单
use app\social\service\PostService;
use support\bootstrap\EsClient;
use support\Redis;
use think\db\PDOConnection;
use Xiaoyangguang\WebmanTracer\core\TracerInitialize;
use Xiaoyangguang\WebmanTracer\example\ElasticsearchAspect;
use Xiaoyangguang\WebmanTracer\example\GenericAspect;
use Xiaoyangguang\WebmanTracer\example\MysqlAspect;
use Xiaoyangguang\WebmanTracer\example\RedisAspect;
TracerInitialize::setConfig(true);
MysqlAspect::setConfig('业务数据库', '127.0.0.1');
RedisAspect::setConfig('业务Redis');
ElasticsearchAspect::setConfig('业务Elasticsearch');
//HttpAspect::setConfig();
return [
RedisAspect::class => [ //追踪类
Redis::class => [ //被追踪类
'__callStatic', //被追踪方法
],
],
ElasticsearchAspect::class => [//追踪类
EsClient::class => [
'__callStatic',//被追踪方法
'__call',//被追踪方法
],
],
MysqlAspect::class => [//追踪类
PDOConnection::class => [ //追踪底层数据库执行方法例子
'getPDOStatement',//被追踪方法
],
],
GenericAspect::class => [ //追踪类 通用追踪节点 任由开发者发挥
PostService::class => [
'searchByIds',
],
],
];
最后启动服务,并测试。
docker run -d --restart always -p 9411:9411 --name zipkin openzipkin/zipkin
php start.php start
curl http://127.0.0.1:8787
在浏览器访问:http://ip:9411/zipkin/查看平台数据
可以啊 !
有时间可以做成插件,这样可以直接安装不用配置,卸载时也可以自动删除配置
https://www.workerman.net/doc/webman/others/plugin.html
好的
workerman有链路追踪插件不呢
这里是不是自定义插件时无法读取自定义的配置文件哦,如果自定义配置文件要放在对应的目录下的话
可以读取
我刚测试了一下不行,在config目录下面建的子目录,config('xxxxx') 是无法读取的,我先看看源码。
需要
config('plugin.tinywan.casbin.permission.basic.model')
这样子读取新版本可以,老版本不可以,改动挺大的