tars-monitor

tars-monitor

tars-monitorphptars 服务与特性监控上报模块

它由两个子模块组成:

  • 服务监控
  • 特性监控

使用方式

安装

使用composer进行安装 composer install phptars/tars-monitor

调用

服务监控上报

  • locator 为上报地址,一般由服务器下发
  • socketMode 设置为 1 使用 socket 方式进行上报 socketMode 设置为 2 使用 swoole tcp client方式进行上报(需要swoole支持) socketMode 设置为 3 使用 swoole tcp coroutine client协程方式进行上报(需要swoole2.0以上支持)

定时上报(默认)

使用定时上报需要 swoole_table支持,通过调用addStat将上报信息暂存,tars-server的task进程会搜集一段时间内(上报时间间隔由服务器下发,一般为60s)统一打包上报,可以减少上报请求

  1. $locator = "tars.tarsregistry.QueryObj@tcp -h 172.16.0.161 -p 17890";
  2. $socketMode = 1;
  3. $statfWrapper = new \Tars\monitor\StatFWrapper($locator,$socketMode);
  4. $statfWrapper->addStat("PHPTest.helloTars.obj","test","172.16.0.116",51003,200,0,0);
  5. $statfWrapper->addStat("PHPTest.helloTars.obj","test","172.16.0.116",51003,200,0,0);
  6. $statfWrapper->addStat("PHPTest.helloTars.obj","test","172.16.0.116",51003,200,0,0);

上报数据可使用多种存储方式,cache中提供了swoole_tableredis的实现方式,用户也可以自己实现contract/StoreCacheInterface,配置存储方式参考demo tars-http-serversrc/services.php 的配置。

  1. return array(
  2. 'namespaceName' => 'HttpServer\\',
  3. 'monitorStoreConf' => [
  4. 'className' => Tars\monitor\cache\SwooleTableStoreCache::class,
  5. 'config' => []
  6. ]
  7. );

monitorStoreConf 为存储方式的配置,其中className为实现类,config 为对应的配置,如使用redis存储方式时,config中需要配置redis的host、port、以及key的前缀等。 未配置monitorStoreConf时默认使用SwooleTableStoreCache进行存储。

单次上报

同时tars-monitor也提供了单次上报的接口monitorStat,即每次tars请求调用均会进行一次上报,该方式不建议使用

  1. $locator = "tars.tarsregistry.QueryObj@tcp -h 172.16.0.161 -p 17890";
  2. $socketMode = 1;
  3. $statfWrapper = new \Tars\monitor\StatFWrapper($locator,$socketMode);
  4. $statfWrapper->monitorStat("PHPTest.helloTars.obj","test","172.16.0.116",51003,200,0,0);

特性监控

参数与服务监控类似

  1. $statfWrapper = new \Tars\monitor\PropertyFWrapper("tars.tarsregistry.QueryObj@tcp -h 172.16.0.161 -p 17890",1);
  2. $statfWrapper->monitorProperty("127.0.0.1","userdefined",'Sum',2);
  3. $statfWrapper->monitorProperty("127.0.0.1","userdefined",'Count',2);
  4. $statfWrapper->monitorProperty("127.0.0.1","userdefined",'Count',1);

监控查看

数据上报后,用户可在服务监控/特性监控选项卡中查看上报的数据。

其他

因为其他模块已经集成了本模块, 所以一般情况下,服务脚本无需显式使用此模块。