首页 » 网站推广 » phpmolten技巧_软件推荐丨Molten系统模块调用链路追踪对象

phpmolten技巧_软件推荐丨Molten系统模块调用链路追踪对象

访客 2024-11-19 0

扫一扫用手机浏览

文章目录 [+]

点击右上方,关注开源中国OSC头条号,获取最新技能资讯

Molten 是运用透明链路追踪工具。

phpmolten技巧_软件推荐丨Molten系统模块调用链路追踪对象

Molten 追踪php核心调用库运行时信息并且按照zipkin/optracing格式输出信息。

phpmolten技巧_软件推荐丨Molten系统模块调用链路追踪对象
(图片来自网络侵删)

Molten 供应多种sapi, 多种采样类型, 上报追踪状态, 模块掌握和多种数据落地 类型等功能。

依赖于Molten 很随意马虎构建基于php措辞的分布式全链路追踪系统 目前已经运行在生产环境上千台机器上。

安装

以下是你须要做的安装molten在你的系统上。

phpize./configuremake && 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 examplesh run.sh

在浏览器中打开 http://127.0.0.1:9411/zipkin/, 能够瞥见链路信息。

如果你认为上述太大略,你可以做下面的操作。

cd examplesh 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\公众:\公众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)。

定制化的链路格式, 支持两个盛行格式(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 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方法要求http://domain/molten/status。

数据是json格式,字段和配置项中的含义是同等的。

{\"大众enable\"大众:1,\公众samplingType\"大众:2,\"大众samplingRate\"大众:20,\公众samplingRequest\"大众:100}

上报

上报模块能够记录,molten并没有采样样到的关键数据信息。

开源社区OSC头条号,逐日推送最新优质的技能类文章,涵盖外文翻译,软件更新,技能博客等优质内容。
关注开源社区OSC头条号,逐日获取最新技能资讯,点击“理解更多”阅读原文章。

↓↓↓

标签:

相关文章

世界语言排名背后的文化影响力与未来趋势

随着全球化进程的加速,世界语言排名成为衡量语言影响力的重要指标。本文将从世界语言排名的角度,探讨各语言背后的文化影响力以及未来发展...

网站推广 2024-12-27 阅读0 评论0

世界前四语言的魅力与影响

在全球化的今天,语言作为一种文化的载体,承载着人类文明的交流与传承。世界前四语言——汉语、英语、西班牙语和阿拉伯语,因其广泛的使用...

网站推广 2024-12-27 阅读0 评论0

自学IT,开启数字化时代的自我赋能之旅

在数字化时代,信息技术(IT)已经成为社会发展的关键驱动力。掌握IT技能,不仅能提升个人竞争力,还能助力实现职业梦想。IT领域的知...

网站推广 2024-12-27 阅读0 评论0

荣盛IT待遇,打造行业标杆,引航未来职场

在互联网时代,IT行业已成为我国经济发展的重要支柱。而作为一家在IT领域具有深厚底蕴的企业,荣盛集团凭借其卓越的IT待遇,吸引了大...

网站推广 2024-12-27 阅读0 评论0