Dubbo-monitor简单介绍
2018-02-01 本文已影响0人
DogF
O、dubbo-monitor介绍
用来统计服务的调⽤次数和调⽤时间的监控中⼼。
data:image/s3,"s3://crabby-images/73db6/73db6de3a87079283f207899c5376155705007fe" alt=""
一、使用方法
1.下载源码:github地址:https://github.com/dubbo/dubbo-ops
2.编译打包项目,拿到assembly包。解压后做相应配置(zk地址/端口号..),bin目录下启动服务。浏览器查看相应图形界面。
data:image/s3,"s3://crabby-images/705d8/705d84caffaec4846389b58b83d4599d0cf53b9d" alt=""
3.dubbo项目配置xml,一般配置protocol=registry,然后会自动读取dubbo-monitor服务,进行打点。
data:image/s3,"s3://crabby-images/6602b/6602bf744975ed598911bc18967a06acdfb23dc2" alt=""
二、代码解释
1.匹配
如果项目中的dubbo配置有增加dubbo:monitor标签,在dubbo的MonitorFilter中会检测该标签,如果有的话,就会调用monitor服务进行统计。
data:image/s3,"s3://crabby-images/95555/95555517a24dca100ef3e87f3fada276fe7594c8" alt=""
2.获取monitor
从dubbo注册中心中找出实现了MonitorService的服务,在“使用方法” 第二步启动monitor服务后,会使用暴露MonitorService服务。
然后通过Monitor封装MonitorService对象返回。
data:image/s3,"s3://crabby-images/7b231/7b2311f6a275c06cb1ef3abdf1dbe36d03c1e323" alt=""
3.本地收集
内存中维护了一个ConcurrentMap,来统计本地每个服务的调用信息(成功、失败、出入参、耗时、当前并发量等)
data:image/s3,"s3://crabby-images/37eb9/37eb9ad6028bfe3252d682e3ab125737caf04a6f" alt=""
4.远程收集
Monitor接口的实现DubboMonitor在初始化时,启动了一个定时任务,定时将本地收集的服务调用信息发往远程服务。使用ScheduledExecutorService.scheduleWithFixedDelay();
任务周期:启动服务1分钟后发送,下一次在上一次发送完成后+1分钟发送。
data:image/s3,"s3://crabby-images/68202/68202cc059051e64dc257d24fcb4d010879a935c" alt=""