Molten 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
Molten 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
Molten 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」 !
Molten 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」「最积极运营项目」 !
Molten 获得 2020 年度 OSC 中国开源项目评选「最积极运营项目」 !

软件简介

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_path2 写入到标准输出, 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并没有采样样到的关键数据信息。

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论 (2)

加载中
这里有个冲突的点,公司做的是php+java混杂的服务架构。但是因为需要做持久连接已经http服务的性能优化等考虑,使用的docker+swoole的模式。 在服务化的模式下这种调用更有价值,而swoole做服务化的php更有优势,但是Molten和swoole有冲突的话,也是麻烦。
2019/01/17 17:02
回复
举报
可以支持swoole吗
2019/01/17 17:00
回复
举报
更多评论
暂无内容
2017/10/20 16:05

当molten遇到机器学习

# 当molten遇到机器学习 ## molten `molten`是一个链路追踪的php扩展, git地址:[molten](https://github.com/chuan-yun/Molten) 它能够用来构建php全链路追踪系统, 这个在上一篇的blog中已经介绍过了《[Molten 功能简介以及使用指南](https://my.oschina.net/u/3635821/blog/1499464)》 在如今机器学习如火如荼的今天, 全链路追踪系统和机器学习相结合 和爆发出怎样的火花? 下面让我们玩转起来这个追踪系统。 ## 机器学习 ...

0
2
2018/08/20 10:22

Linux 安装molten

``` 0.zipkin 开源分布式系统调用跟踪工具 molten为php作对应的数据收集 1.molten安装相关请参考 https://github.com/chuan-yun/Molten 2.mkdir /usr/local/molten 3.git clone https://github.com/chuan-yun/Molten.git /usr/local/molten 4.安装依赖 yum install libevent-devel (或 apt-get install libevent-dev) 5.cd /usr/local/molten 6.phpize 7../configure --enable-zipkin-header=yes 8.make && make install 9.在/...

0
0
发表于AI & 大数据专区
2019/11/22 16:57

【PHP】关于系统性能追踪工具molten

一、简介 关于molten的介绍网上有很多,是一个全链路追踪的工具,Molten可以看做是phptrace的的升级版(流行的php问题定位工具譬如phptrace,xhprof,这些工具可以自行Google,看看如何使用) Molten能干啥 molten追踪php核心调用库运行时信息并且按照zipkin/optracing格式输出信息。 可以追踪`curl,pdo,mysqli,redis,mongodb,memcached` 这么多的运行信息。 你可以直接看到你耗时比较久的接口的运行信息,调用信息,一眼就能看...

0
0
发表于开发技能专区
2019/12/14 00:33

PHP 全链路追踪 Molten-Docker

#Dockerfile FROM daocloud.io/php:7.2-fpm-alpine ENV TIME_ZONE=Asiz/Shanghai RUN apk add linux-headers # Compile Molten RUN set -xe && \ curl -LO https://github.com/chuan-yun/Molten/archive/v0.1.1.tar.gz && \ tar xzf ${PWD}/v0.1.1.tar.gz && \ #cd ./v0.1.1 && phpize && ./configure && make && make install\ docker-php-ext-configure ${PWD}/Molten-0.1.1 && \ d...

0
0
发表了博客
2014/11/13 17:02

Steel Rolling Mill Technology

http://www.timothyholding.com/ Steel Rolling Mill Technology Steel Mill Operation Hot Rolling Cold Rolling Cold rolling occurs when the steel is at a temperature below its recrystallization temperature. This increases the steel's strength via strain hardening, or hardening that is produced via dislocation movements within a material's crystal structure. Cold rolled materials are often smaller b...

1
0
发表了博客
2020/07/29 12:02

API返回延迟,FPM重启后恢复之后又重现 问题解决方案

背景 最近在提供后台API时,提供了一个简单逻辑的接口 部署在测试环境,自测没问题,提交测试 突然有一天,接口响应延迟严重,几乎每次都是3-4秒返回 这对于一个接口来说,肯定是有问题的 于是便有了以下的方法尝试 重启FPM 最开始以为不是什么大问题,猜想可能是fpm问题 毕竟测试环境,部署代码繁多 重启后,接口响应正常,可不一会就又复现 重新分析定位问题 经过几次的尝试后,发现问题其实没有那么简单 重启fpm后,过了不到几...

0
0
发表了博客
2018/11/14 21:00

PHP工作流

利用本篇文章整理记录一下我的PHP工作流,本篇文章只代表了我目前的对php开发工作流的理解,本文会随时更新 IDE PhpStorm 不解释,反正无论你用什么,最后还是会回到这个上面,我就是不信邪,折腾了一圈,还是乖乖的用了它. 包管理 composer PHP检查 PHP_CodeSniffer PHP编码检测程序 PHP-CS-Fixer PHP编码标准修复程序 PHPStan PHP静态分析工具,不运行代码便发现BUG 测试 phpunit 调试 XDEBUG Molten phptrace 代码管理工具 GIT gitK...

0
0
发表了博客
2013/12/19 09:49

Classical Blow Molding Machines

Classical Blow Molding Machine is a action acclimated to anatomy thermoplastic abstracts and PET Draft Molding Machines are broadly acclimated for authoritative bottles. Advanced technology in plastics industry has accustomed acceleration to a amount of Draft Molding Machines. The alive assumption of Draft Molding Machines comes from the 20th aeon abstraction of glassblowing. Draft Molding Mach...

0
0
发表了博客
2014/11/13 17:04

Ladle Cranes

http://www.timothyholding.com/ http://www.timothyholding.com/ Features of ladle cranes Ladle cranes are designed to be operated efficiently, uninterruptedly and safely in continuous use. The design conforms to the requirements of international standards. Because of a higher risk level, special safety features are designed for the ladle cranes that transport molten metal. The main hoist mechanis...

1
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
暂无内容
2 评论
40 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部