资料介绍
软件简介
Molten 是应用透明链路追踪工具。
Molten 追踪php核心调用库运行时信息并且按照zipkin/optracing格式输出信息。
Molten 提供多种sapi, 多种采样类型, 上报追踪状态, 模块控制和多种数据落地 类型等功能。
依赖于Molten 很容易构建基于php语言的分布式全链路追踪系统 目前已经运行在生产环境上千台机器上。
安装
以下是你需要做的安装molten在你的系统上。
phpize ./configure make && make install
make install
复制 molten.so
到确切的位置, 但是你还需要开启模块在php配置中,编辑你自己的php.ini或者添加molten.ini在/etc/php5/conf.d
, 并且添加如下内容:extension=molten.so
。
在./configure
阶段, 你也可以添加 --enable-zipkin-header=yes
支持zipkin B3 header。
快速开始
cd example sh run.sh
在浏览器中打开 http://127.0.0.1:9411/zipkin/
, 能够看见链路信息。
如果你认为上述太简单,你可以做下面的操作。
cd example sh complex.sh
怎么样,是不是很酷。
注意
如果没有看到详细信息,那么EndTime选项中添加1小时。
配置
基础配置
molten.enable
1开启0关闭, 默认 1
。
molten.service_name
设置应用服务名, 默认default
。
molten.tracing_cli
1追踪cli模式下信息, 0关闭, 默认0
。
采样配置
molten.sampling_type
类型类型, 1采样率控制, 2通过每分钟request数, 默认是1
。
molten.sampling_request
采样类型是请求数采样,每分钟的采样请求数, 默认是10
。
molten.sampling_rate_base
采样类型是采样率时,每个请求的采样几率, 默认是256
。
控制模块配置
molten.notify_uri
通知管理中心的uri。
上报模块配置
上报模块使用和数据模块相同的输出类型。
molten.report_interval
数据模块调用间隔, 默认 60
。
molten.report_limit
数据上报请求上限, 默认 100
。
数据模块
molten.sink_type
数据落地类型, 1
写入文件, 文件地址依赖molten.sink_log_path
, 2
写入到标准输出, 3
写入到syslog中, 4
通过curl发送, 发送地址依赖 molten.sink_http_uri
.
molten.output_type
输出全部追踪块(span)(1
) 或者一行输出一个块(2
)。
molten.sink_log_path
写入文件地址。
molten.sink_http_uri
发送http地址。
molten.sink_syslog_unix_socket
发送日志到syslog udp unixdomain日志收集源中。
追踪块配置
molten.span_format
追踪块格式(span), 不同的追踪系统选择zipkin
或者 zipkin_v2
或者 opentracing
。
函数
molten_span_format()
获取当前追踪系统span格式, 返回zipkin或者opentracing字符串。
molten_get_traceid()
获取当前上下文的traceiid,返回16进制的字符串。
molten_set_traceid($trace_id)
设置当前上下文的额traceiid, 无返回。
验证
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":"Failed connect to localhost:12345; Connection refused","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)。
定制化的链路格式, 支持两个流行格式(zipkin
和 opentracing
)。
采样
两种不同的采样方式并且能够通过控制模块进行修改。
数据落地
molten当前支持3种数据落地方式,标准输出,文件,http。并且能够选择输出的位置。
控制
使用http协议控制探针的行为。
查看molten的状态, 通过GET方法请求http://domain/molten/status
。
输出内容如下,已经适配了prometheus格式。
# HELP molten_request_all Number of all request. # TYPE molten_request_all counter molten_request_all %d # HELP molten_request_capture Number of request be capture. # TYPE molten_request_capture counter molten_request_capture %d # HELP molten_sampling_type the type of sampling. # TYPE molten_sampling_type gauge molten_sampling_type %d # HELP molten_sampling_rate the rate of sampling. # TYPE molten_sampling_rate gauge molten_sampling_rate %d # HELP molten_sampling_request the request be capture one min. # TYPE molten_sampling_request gauge molten_sampling_request %d
修改molten采样方式, 使用POST方法请求http://domain/molten/status
。
数据是json格式,字段和配置项中的含义是一致的。
{"enable":1,"samplingType":2,"samplingRate":20,"samplingRequest":100}
上报
上报模块能够记录,molten并没有采样样到的关键数据信息。
- 探讨高度计在健身追踪器中的作用 17次下载
- 拼版工具 0次下载
- pcb阻抗计算工具 35次下载
- 差分线阻抗计算工具 36次下载
- HP点位图工具安装程序下载 16次下载
- EDA工具CADENCE原理图与PCB设计说明 50次下载
- 基于灰狼优化算法的机器人源定位追踪 5次下载
- 基于LoRa无线射频信号的行走追踪系统 8次下载
- 液晶电视升级工具mboot使用及强制升级方法 11次下载
- 蓝牙调试工具BTool v1.40.5资源下载 25次下载
- 透明电视是怎么做成透明的?其实你也可以DIY资料下载 8次下载
- 16位CRC验证码生成VI工具下载 50次下载
- 软件工具Altium Designer免费下载入口 69次下载
- 一种基于多智能体协同强化学习的多目标追踪方法 20次下载
- 透明加密软件的特点及原理 0次下载
- 基于OpenVINO在英特尔开发套件上实现眼部追踪 393次阅读
- 动态追踪威廉希尔官方网站 分类及其使用方法 1995次阅读
- 链路追踪系统SkyWalking的原理 3187次阅读
- 一个实时单目追踪和稠密建图的算法框架TANDEM算法研究 649次阅读
- 新规划PCI核查工具的使用方法和应用事例 2435次阅读
- 如何通过雷达追踪飞机 4666次阅读
- dfrobotUNO R3开发板透明ABS外壳介绍 1830次阅读
- 什么是眼球追踪?为什么对VR如此重要? 7343次阅读
- 耐高压透明液压节流阀的原理及设计 1090次阅读
- OpenCV上八种不同的目标追踪算法 3.1w次阅读
- 介绍透明显示的核心材料之一的透明电极所要具备的条件 1.2w次阅读
- 如何构建完全透明的柔性电路 4509次阅读
- 光线追踪算法汇总 1.6w次阅读
- 透明手机是怎样的手机_手机如何做到透明_透明手机有啥用 1.1w次阅读
- 一文解读透明手机发展及威廉希尔官方网站 原理 8760次阅读
下载排行
本周
- 1山景DSP芯片AP8248A2数据手册
- 1.06 MB | 532次下载 | 免费
- 2RK3399完整板原理图(支持平板,盒子VR)
- 3.28 MB | 339次下载 | 免费
- 3TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 4DFM软件使用教程
- 0.84 MB | 295次下载 | 免费
- 5元宇宙深度解析—未来的未来-风口还是泡沫
- 6.40 MB | 227次下载 | 免费
- 6迪文DGUS开发指南
- 31.67 MB | 194次下载 | 免费
- 7元宇宙底层硬件系列报告
- 13.42 MB | 182次下载 | 免费
- 8FP5207XR-G1中文应用手册
- 1.09 MB | 178次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33566次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21549次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6656次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537798次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420027次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191187次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183279次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多