-
Notifications
You must be signed in to change notification settings - Fork 160
Home
现今随着应用间调用的复杂化,php 开发者们在复杂调用链路追踪上并没有特别好的工具和方法, 流行的php问题定位工具譬如phptrace,xhprof等并不会针对于远程调用进行重点分析,比较适合单机应用。当php分布式系统需要明确组件调用关系的时候,这些工具很难发挥作用。
在这里我们抛出google在2010年提出的概念dapper-大规模分布式应用追踪系统
,其中提出的分布式追踪系统的构想已经被一些公司或组织所实现,譬如zipkin
、opentracing
。但是遗憾的是,现今没有比较让人认可应用透明php追踪方式。
chuan-yun组织实现的php扩展Molten已经解决了这个问题,它部署简单、应用透明、配置项丰富、兼容zipkin和opentracing标准、能够追踪众多基础组件,并且通过修改http请求header实现了应用透明的链路串联。
我们能够用molten做什么呢,请看项目简介中“QuickStart”部分,安装完molten扩展之后, 只需要两个步骤就可以看到追踪的链路信息。
cd example && sh run.sh:
上图中的系统是zipkin server链路内容,也就是说我们部署完molten,配置好zipkin server 就能够搭建一个简单的全链路追踪系统,方便易用。 上述示例太小?咱们展示一个复杂的链路追踪。
Cd example && sh complex.sh:
示例中启动了3个server,t1_server和t2_server都去请求base_server 这些http 请求构建成了一个完整的链路信息,构建了一个php全链路系统就是这么就简单!!
现在Molten提供curl、pdo、mysqli、redis、mongodb、memcached等组件的拦截,这些信息拦截都是应用透明,开箱即用,输出zipkin格式非常方便。我们接下来还会增加拦截的组件,如果你也有想要拦截的组件,可以提issue给我们偶!!项目地址。
查看molten是否正常启动了,可以访问:http://your.domain/molten/status:
面输出内容格式让人感到疑惑,其实这个是prometheus监控exporter输出格式,输出这种格式方便和prometheus集成。
还可以通过POST http://your.domain/molten/status修改探针采样的方式,内容如下:
{"enable":1,"samplingType":2,"samplingRate":20,"samplingRequest":100}
其中samplingType是采样类型:1是根据采样率采样,2是根据每分钟的请求数。
samplingRate是采样率,即多少个请求采样一个,samplingRequest是每分钟的前多少个请求被采样。采样是降低性能损耗的有效方式,通过还能够根据系统的承载量动态的调整。
还可通过molten.sink_type设置数据输出方式, 1是输出到文件中, 2输出到标准输出,4 通过http发送。
Molten在phptrace数据分析的基础上进行大量的开发, 本身性能在开启采样率的情况下影响较小。应用影响如下:
开启探针传递链路信息对比(采样率) | 性能影响 |
---|---|
1 | 21% |
4 | 12% |
8 | 8% |
32 | 6% |
64 | 9% |
256 | 8% |
这个项目是不是勾起了你的好奇心? 来吧让你的issue砸向我们,我们会提供更加丰富和完善的功能。最后请不要吝惜你的start :)。
微信群:
项目地址:https://github.com/chuan-yun/Molten
中文文档:https://github.com/chuan-yun/Molten/blob/master/README_ZH.md
英文文档:https://github.com/chuan-yun/Molten/blob/master/README.md
all we do is to support you !!!!!