webman链路追踪插件

小阳光

webmanTracer插件使用教程

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/查看平台数据


1934 3 3
3个评论

Tinywan

可以啊 !

  • 暂无评论
walkor

有时间可以做成插件,这样可以直接安装不用配置,卸载时也可以自动删除配置
https://www.workerman.net/doc/webman/others/plugin.html

小阳光

这里是不是自定义插件时无法读取自定义的配置文件哦,如果自定义配置文件要放在对应的目录下的话

  • walkor 2022-01-11

    可以读取

  • 小阳光 2022-01-11

    我刚测试了一下不行,在config目录下面建的子目录,config('xxxxx') 是无法读取的,我先看看源码。

  • Tinywan 2022-01-11

    需要 config('plugin.tinywan.casbin.permission.basic.model') 这样子读取

  • 小阳光 2022-01-12

    新版本可以,老版本不可以,改动挺大的

年代过于久远,无法发表评论

小阳光

1467
积分
0
获赞数
0
粉丝数
2020-04-02 加入
🔝