Skip to content
silkCut edited this page Oct 13, 2017 · 4 revisions

Molten 功能简介以及使用指南

简介

现今随着应用间调用的复杂化,php 开发者们在复杂调用链路追踪上并没有特别好的工具和方法, 流行的php问题定位工具譬如phptrace,xhprof等并不会针对于远程调用进行重点分析,比较适合单机应用。当php分布式系统需要明确组件调用关系的时候,这些工具很难发挥作用。

在这里我们抛出google在2010年提出的概念dapper-大规模分布式应用追踪系统,其中提出的分布式追踪系统的构想已经被一些公司或组织所实现,譬如zipkinopentracing。但是遗憾的是,现今没有比较让人认可应用透明php追踪方式。

chuan-yun组织实现的php扩展Molten已经解决了这个问题,它部署简单、应用透明、配置项丰富、兼容zipkin和opentracing标准、能够追踪众多基础组件,并且通过修改http请求header实现了应用透明的链路串联。

快速开始

我们能够用molten做什么呢,请看项目简介中“QuickStart”部分,安装完molten扩展之后, 只需要两个步骤就可以看到追踪的链路信息。

cd example && sh run.sh:

image

上图中的系统是zipkin server链路内容,也就是说我们部署完molten,配置好zipkin server 就能够搭建一个简单的全链路追踪系统,方便易用。 上述示例太小?咱们展示一个复杂的链路追踪。

Cd example && sh complex.sh:

image

示例中启动了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:

image

面输出内容格式让人感到疑惑,其实这个是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 :)。

加入我们

微信群: image

项目文档

项目地址: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