在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
moltenmolten是应用透明链路追踪工具。 molten追踪php核心调用库运行时信息并且按照zipkin/optracing格式输出信息。 molten提供多种sapi, 多种采样类型, 上报追踪状态, 模块控制和多种数据落地类型等功能。 依赖于molten很容易构建基于php语言的分布式全链路追踪系统目前已经运行在生产环境上千台机器上。 目录安装以下是你需要做的安装molten在你的系统上。 phpize./configuremake && make install
在 快速开始cd examplesh run.sh 在浏览器中打开 如果你认为上述太简单,你可以做下面的操作。 cd examplesh complex.sh 怎么样,是不是很酷。
配置基础配置
采样配置
控制模块配置
上报模块配置上报模块使用和数据模块相同的输出类型。
数据模块
追踪块配置
函数
验证php -d extension=molten.so -d molten.enable=1 -d molten.sink_type=2 -d molten.tracing_cli=1 -d molten.sampling_rate=1 -r '$c=curl_init("http://localhost:12345");curl_exec($c);' 可以看到如下输出: [{"traceId":"%s","name":"php_curl","version":"php-4","id":"1.1","parentId":"1","timestamp":%d,"duration":%d,"annotations":[{"value":"cs","timestamp":%d,"endpoint":{"serviceName":"%s","ipv4":"%s"}},{"value":"cr","timestamp":%d,"endpoint":{"serviceName":"%s","ipv4":"%s"}}],"binaryAnnotations":[{"key":"http.url","value":"http:\/\/localhost:12345\/","endpoint":{"serviceName":"%s","ipv4":"%s"}},{"key":"error","value":"Failedconnect to localhost:12345; Connectionrefused","endpoint":{"serviceName":"%s","ipv4":"%s"}}]},{"traceId":"%s","name":"cli","version":"php-4","id":"1","timestamp":%d,"duration":%d,"annotations":[{"value":"sr","timestamp":%d,"endpoint":{"serviceName":"%s","ipv4":"%s"}},{"value":"ss","timestamp":%d,"endpoint":{"serviceName":"%s","ipv4":"%s"}}],"binaryAnnotations":[{"key":"path","value":"-","endpoint":{"serviceName":"%s","ipv4":"%s"}}]}] 功能从上述配置中,你可以看到我们提供的功能。 拦截器molten 拦截 curl,pdo,mysqli,redis,mongodb,memcached扩展,构建运行时追踪信息. 支持全链路追踪功能, molten 替换了curl_exec,curl_setopt,curl_setopt_array函数, 并且在请求中添加了链路头(x-w-traceid, x-w-spanid and so on)。 定制化的链路格式, 支持两个流行格式( 采样两种不同的采样方式并且能够通过控制模块进行修改。 数据落地molten当前支持3种数据落地方式,标准输出,文件,http。并且能够选择输出的位置。 控制使用http协议控制探针的行为。 查看molten的状态, 通过GET方法请求 输出内容如下,已经适配了prometheus格式。 # HELP molten_request_all Number of all request.# TYPE molten_request_all countermolten_request_all %d# HELP molten_request_capture Number of request be capture.# TYPE molten_request_capture countermolten_request_capture %d# HELP molten_sampling_type the type of sampling.# TYPE molten_sampling_type gaugemolten_sampling_type %d# HELP molten_sampling_rate the rate of sampling.# TYPE molten_sampling_rate gaugemolten_sampling_rate %d# HELP molten_sampling_request the request be capture one min.# TYPE molten_sampling_request gaugemolten_sampling_request %d 修改molten采样方式, 使用POST方法请求 数据是json格式,字段和配置项中的含义是一致的。 {"enable":1,"samplingType":2,"samplingRate":20,"samplingRequest":100} 上报上报模块能够记录,molten并没有采样样到的关键数据信息。 Contributing欢迎开发者们使molten变得更好。 您可以联系如下邮件列表来讨论。 你还可以通过以下方式贡献。
协议Apache License Version 2.0 see http://www.apache.org/licenses/LICENSE-2.0.html |
请发表评论