软件简介

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并没有采样样到的关键数据信息。

mysql链路追踪工具_Molten相关推荐

  1. mysql链路跟踪工具_SkyWalking全链路追踪利器

    随着目前系统架构的复杂度越来越高(中台.微服务),并且线上应用的多级监控覆盖到了通讯.应用处理过程监控并且实现端到端的应用监测,线上性能故障的快速定位修复:而传统的监控分析方式已经无法满足我们的需求, ...

  2. 链路追踪工具 skywalking

    链路追踪工具 skywalking 一.关于应用性能监控 APM(Application Performance Monitor) 对于单体应用,性能分析相对简单,不同的语言都提供了工具,在代码层面埋 ...

  3. mysql链路跟踪工具_EasySwoole利用链路追踪组件制作甩锅工具

    前言 最近前端老是反馈API调用异常,说请求成功但是没有数据返回! 我写的代码怎么可能有bug,肯定是前端调用的方式不对! 经过一番套鼓,直接把请求参数和响应内容打印到控制台,果然不出我所料,请求缺少 ...

  4. 专为云原生、微服务架构而设计的链路追踪工具 【SkyWalking介绍及搭建】

    文章目录 前言. 当前企业级分布式微服务集群架构图 一. skywalking是什么 二. 为什么需要服务追踪 三 链路追踪框架对比 3.1 性能对比 四. 链路追踪的实际应用预览 4.1 捋清业务 ...

  5. 分布式链路追踪工具skywalking 介绍

    当企业应用进入分布式微服务时代,应用服务依赖会越来越多,skywalking可以很好的解决服务调用链路追踪的问题,而且基于java探针技术,基本对应用零侵入零耦合. skywalking是什么,有什么 ...

  6. skywalking 安装_SkyWalking全链路追踪利器

    随着目前系统架构的复杂度越来越高(中台.微服务),并且线上应用的多级监控覆盖到了通讯.应用处理过程监控并且实现端到端的应用监测,线上性能故障的快速定位修复:而传统的监控分析方式已经无法满足我们的需求, ...

  7. 监控链路追踪Tracing Skywalking(二)

    1.需求 ​ 公司项目采用微服务的架构,服务很多,人工监控是不可能的,项目的访问量很大,想通过日志查找某个方法中性能的问题也是非常困难的.但是系统的性能问题是不能忽视的.系统性能检测的问题如鲠在喉,经 ...

  8. Skywalking全链路追踪使用说明

    1.背景与需求: 随着业务规模的不断增大,系统的复杂度也越来越高,我们的软件架构也进入了分布式的阶段,服务按照不同的维度进行拆分,那么一次请求可能横跨多个服务模块.项目,依赖的中间件也越来越多,其中任 ...

  9. 【全链路追踪】全链路追踪介绍

    什么是链路追踪? 链路追踪是一种针对分布式架构下实现请求链路可视化监控的一种技术. 它的核心目的就是去了解分布式系统中的请求调用行为,从而从整体到局部详细展示各项系统指标. 实现故障的快速定位,缩短故 ...

  10. PHP分布式链路追踪,SkyWalking:分布式架构链路追踪-SkyWalking介绍

    前面几篇文章提到了微服务相关系统的使用与搭建,在微服务架构下的问题也比较突出.正常系统下我们的每个请求都会在同一个系统中进行输出.但是在微服务架构中一个请求可能设置一到多个服务进行处理.服务之间相互依 ...

最新文章

  1. 两数之和——双指针法
  2. 系统 CPU 突然飙升且 GC 频繁,如何排查
  3. ThreadLocal介绍以及源码分析
  4. android sdk版本兼容,Android 版本兼容
  5. Microsoft SQL Server 2019开发版安装配置教程
  6. 部署egg需要用到pm2吗_使用宝塔面板部署校园综合服务平台项目
  7. php求北京时间方法,php怎么将获得的时间转换为北京时间
  8. Shiro————核心设计思想
  9. js中的数组基本知识
  10. 【转】implicit declaration of function 这种警告问题的原因及解决方法
  11. Centos 安装最新版git
  12. 对付U盘病毒彻底免疫
  13. python 断言详细讲解用法及其案例_Python断言的最佳实践
  14. 不 只{`pyr_PYR的完整形式是什么?
  15. php excel引入tp,TP 引入phpExcel
  16. KDEUnivariate.fit 参数详解
  17. 计算机专业车辆控制,智能无人驾驶汽车的计算机控制系统详细介绍和要求及设计资料概述...
  18. 知识文库杂志知识文库杂志社知识文库编辑部2022年第14期目录
  19. 如何处理​PHP 表单?
  20. Java小工具:B站视频选集搜索器--获取选集信息

热门文章

  1. nextdate函数 c语言,NextDate函数包含3个变量month,day和year,函数的输出为输入日期后一天日期.要求month,day和year满足下列...
  2. SAP系统常用配置参数设定
  3. kubernetes的基本概念及安装部署
  4. django improperly configured
  5. KMP --算法竞赛(33)
  6. python六边形网格_六边形网格地图算法细节介绍
  7. Suspense组件的使用
  8. IDEA “Cannot resolve symbol” 解决办法
  9. 如何查看当前域名的注册信息?
  10. 域名解析不生效,中科三方带你定位!