前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用基于 tideways 的 php-monitor 搭建 PHP 性能监控平台

使用基于 tideways 的 php-monitor 搭建 PHP 性能监控平台

作者头像
菜皮日记
发布2023-12-18 14:16:08
2430
发布2023-12-18 14:16:08
举报
文章被收录于专栏:菜皮日记菜皮日记
tideways、xhprof、xhgui 介绍

代码语言:javascript
复制
tideways 是一家提供 PHP 应用性能监控相关服务的公司,最主要的产品是 tideways PHP 性能监控扩展,tideways 扩展能够监控请求耗时,SQL 执行耗时,CPU 和内存占用。监控数据存储支持MySQL 和 MongoDB。
代码语言:javascript
复制
提到 PHP 性能监控,不得不提性能监控工具 xhprof。xhprof 是 facebook 开发并开源的 PHP 性能监控扩展,配合 xhgui 做数据的可视化。但由于 facebook 后期将自家 PHP 替换成 HHVM,xhprof 也不再维护了。之后 tideways 演化出了两个分支,一个是原本的 tideways 扩展,一个是继承自xhprof 的 tideways_xhprof 扩展,tideways_xhprof 内的功能与 xhprof 一致。在演化成两个分支后,原有的 tideways 逐渐演化成了付费的 SaaS 服务,而 tideways_xhprof 兼容了 xhprof 的一些使用习惯,并会一直维护。
notion image
notion image
代码语言:javascript
复制
产生分支前的最后一个版本:https://github.com/tideways/php-xhprof-extension/tree/v4.1.7
代码语言:javascript
复制
产生分支后的第一个版本:https://github.com/tideways/php-xhprof-extension/tree/v5.0-beta1
php-monitor 介绍
代码语言:javascript
复制
在 xhprof 不维护之后,其对应的数据可视化 xhgui 也就随之不再更新。php-monitor 的作者最开始是为了做一版汉化的 xhgui:xhgui-branch。之后作者又结合 tideways 扩展做了 php-monitor,一个 PHP 性能监控平台,同时支持监控数据收集和数据可视化展示。
配置过程

tideways 扩展

代码语言:javascript
复制
先安装 tideways 扩展。如果使用 PHP 5.6,请下载 tideways v4.1.5。如果使用 PHP7+ ,请下载v4.1.7(更高的版本无法显示SQL)。
代码语言:javascript
复制

wget --no-check-certificate https://github.com/tideways/php-xhprof-extension/archive/v4.1.7.tar.gz && tar zxvf v4.1.7.tar.gz && cd php-xhprof-extension-4.1.7 && phpize && ./configure && make && sudo make install

项目中引入 php-monitor

首先要明确,php-monitor 包含两部分,数据收集和数据可视化。数据收集需要将 php-monitor 整合进项目中,数据可视化部分则单独部署。这两块的数据部分互通即可。

之后尝试在 swoole 项目中引入 php-monitor,首先发现 php-monitor 没有发布到 packagist,所以只能本地安装。

监控数据存储

数据存储使用 MongoDB,方便快捷。

项目是在本地 docker-compose 下起来的,在 docker-compose.yml 中创建一个 mongo 容器并向外暴露 mongo 端口27017。同时 php-monitor 的数据可视化部分也可以在 mongo 中读取监控数据。

docker-compose.yml 声明 mongo

代码语言:javascript
复制

my-mongodb:
container_name: my-mongodb
image: mongo:4.0.3
restart: always
volumes:
  - ./mongodata/db:/data/db
  - ./mongodata/log:/var/log/mongodb
ports:
  - 27017:27017
networks:
  - my-networks
environment:
  MONGO_INITDB_ROOT_USERNAME:
  MONGO_INITDB_ROOT_PASSWORD:
代码语言:javascript
复制
在 php-monitor/src/config/config.php 中配置使用 mongo,在 swoole 处理请求的函数中开启监控,并在返回后记录数据
代码语言:javascript
复制

public function onRequest(SwooleRequest $request, SwooleResponse $response)
{
    require_once '/working/vendor/laynefyc/php-monitor/src/autoPrepend.php';
    // 处理
    \pm\common\PMonitor::shutdown($uri, '127.0.0.1','GET');
}

在 mongo 中可以看到监控数据:

notion image
notion image
代码语言:javascript
复制
其中 profile 字段是具体的调用栈情况,a ==> b 表示从 a 函数到 b 函数的过程
  • ct:调用的次数
  • wt:函数方法执行的时间耗时。相当于,在调用前记录一个时间,函数方法调用完毕后,计算时间差。
  • cpu:函数方法执行消耗的 cpu 时间。和 wt 的差别在于,当进程让出 cpu 使用权后,将不再计算 cpu 时间。通过调用系统调用 getrusage 获取进程的占用 cpu 数据。
  • mu:函数方法所使用的内存。相当于,在调用前记录一个内存占用,函数方法调用完毕后,计算内存差。调用的是 zend_memory_usage 获取内存占用情况。
  • pmu:函数方法所使用的内存峰值。调用的是 zend_memory_peak_usage 获取内存情况。

数据可视化

使用同样的 mongo 配置,在 php-monitor/public 中启动服务 php -S 127.0.0.1:8066

浏览器访问:

notion image
notion image

按url查询耗时:

notion image
notion image

查看具体一次请求的 SQL 耗时详情:

notion image
notion image

函数的耗时和内存占用:

notion image
notion image

函数调用次数和总耗时:

notion image
notion image
性能指标监控的原理

使用 tideways 扩展提供的 tideways_enable 开启监控,tideways_disable 结束监控。可以监控到这两个函数之间的所有执行过程。这一点跟 xhprof一致,也是 xhprof_enable 开启,xhprof_disable 结束。

xhprof扩展:

代码语言:javascript
复制

// 开启监控
xhprof_enable();

// 业务逻辑

// 结束监控
$xhprofData = xhprof_disable();

tideways扩展:

代码语言:javascript
复制

// 开启监控并支持CPU和内存监控
tideways_enable(TIDEWAYS_FLAGS_CPU | TIDEWAYS_FLAGS_MEMORY);
// 开启sql监控
tideways_span_create('sql');

// 业务逻辑

// 结束监控
$monitorData = tideways_disable();
// sql监控
$sqlData = tideways_get_spans();

tideways_xhprof扩展:

代码语言:javascript
复制

// 开启监控并支持CPU和内存监控
tideways_xhprof_enable(TIDEWAYS_XHPROF_FLAGS_MEMORY | TIDEWAYS_XHPROF_FLAGS_CPU);

// 业务逻辑

// 结束监控
$monitorData = tideways_xhprof_disable();
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • tideways、xhprof、xhgui 介绍
  • php-monitor 介绍
  • 配置过程
  • 性能指标监控的原理
相关产品与服务
应用性能监控
应用性能监控(Application Performance Management,APM)是一款应用性能管理平台,基于实时多语言应用探针全量采集技术,为您提供分布式性能分析和故障自检能力。APM 协助您在复杂的业务系统里快速定位性能问题,降低 MTTR(平均故障恢复时间),实时了解并追踪应用性能,提升用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档