OneAPM PHP性能管理平台测试

Stella981
• 阅读 811

从事PHP开发多年,一直在用XHProf工具调试和解决一些程序的性能问题。XHProf的分析报告虽然提供了基于浏览器的报表界面,但是只提供了函数调用图表,没有更多的图表展示。最近发现国内厂商OneAPM在公测PHP的性能管理产品,很好奇试用了一下,说说测试下来的感受。

1.安装

总体安装非常简单,在OneAPM网站上下载OneAPM PHP Agent,按照页面提示的,几分钟就安装完了,非常容易上手。

OneAPM PHP性能管理平台测试

安装完后,访问phpinfo可以看到成功加载了OneAPM模块:

OneAPM PHP性能管理平台测试

2.测试

在测试环境里搭建了一个WordPress应用,后端用MySQL 5.5数据库,简单建了几个页面,发了几篇文章,然后用爬虫不断地抓测试网站的内容来看这个APM工具能采集到什么性能数据。

报表

探针安装完以后,大概5分钟之内就可以从报表上看到性能数据了。OneAPM的图表非常不错,非常直观和清晰。主要有以下几大块的数据展示。

总览

各种性能数据的汇总报表,例如响应时间,吞吐量,错误率什么的。响应时间还可以分成Web事务和数据库两个层次来看。提供了一个Apdex分数的统计,大概了解了一下,好像是用一个分数来评估用户体验满意度的。

 OneAPM PHP性能管理平台测试

拓扑

应用的拓扑架构图,显示应用程序调用数据库的关系。

OneAPM PHP性能管理平台测试

事务

按URL统计的性能数据,看看哪个URL的响应最慢?按响应时间排序。

OneAPM PHP性能管理平台测试

还可以钻取,可以看到某一个页面对数据库的调用耗时,以表名-操作名显示,例如图上可以看到两次wp_options-update的操作导致了两次性能波峰。

OneAPM PHP性能管理平台测试

Traces数据,好像是记录响应最慢的请求的详细数据的。

OneAPM PHP性能管理平台测试

点击可以查看更详细数据,例如可以看到代码段的耗时,代码调用堆栈,参数和SQL等调用的详情。代码调用堆栈的功能非常棒,可以定位到具体哪个方法慢。

OneAPM PHP性能管理平台测试

OneAPM PHP性能管理平台测试

SQL

按SQL语句统计的性能图表,可以发现哪个SQL语句最慢。这里和上面的图一样,也是按表名-操作名的一个组合来统计的。不知道能不能按实际的SQL语句来统计?

OneAPM PHP性能管理平台测试

对选定的SQL语句,可以查看其响应时间与吞吐量的关系,还有调用者时间占比

OneAPM PHP性能管理平台测试

对于查询比较慢的SQL会保留最慢SQL记录,好像是查询时间超过500ms的都会记录下来,不知道在哪里调这个值?

OneAPM PHP性能管理平台测试

点击进去以后可以看到详细的原始SQL语句:

OneAPM PHP性能管理平台测试

错误

提供应用错误率的统计。让我惊讶的是,测试用的WordPress的错误率竟然最高达到10%?好像有点问题吧?因为从爬虫日志里没看到任何报错信息。

OneAPM PHP性能管理平台测试

还好提供了详细错误日志的功能,点击进去发现都是警报级别的错误信息,实际上不影响性能也不影响用户的正常访问,建议能把错误统计的级别提高或者让我可以自己设置。不过错误日志还算详细,可以显示出错的代码行号。

 OneAPM PHP性能管理平台测试

报表

好像是两周内统计数据的一个对比汇总表格,不知道为啥叫做“报表”,难道前面的哪些图表不是报表?建议改成“对比”更合适。

OneAPM PHP性能管理平台测试

设置

又是一个文不对题的菜单项,里面提供的实际上是应用服务器环境变量的报表,显示PHP版本,操作系统版本,各PHP配置文件里的配置。没有任何与设置有关的东西。

OneAPM PHP性能管理平台测试

3.问题

总体测试下来,功能还算不错,可以非常方便地查看性能问题点,包括SQL的性能问题。只不过在功能划分上出现一些文不对题的产品设计上的错误,另外还有两个功能(外部服务,后台任务)始终没有数据,不知道是干什么用的?

有个比较严重的问题是稳定性问题,测试环境搭好之后,就在那里一直跑着,我本来是想过几天在仔细看看数据写测试报告,后来OneAPM的技术支持在QQ上问是不是停了测试?才发现出了问题。在跑了一天不到的时间之后,从报表上就没有任何新的数据了(这也是为什么之前的截图都到2月10号之后就没数据了。)但是我的应用还活着,而且爬虫的访问也正常。在对方的协助下,查了探针的进程日志,发现探针进程已经挂掉了。把日志反馈给了对方的技术支持。

OneAPM PHP性能管理平台测试

这应该算是这次测试中一个比较严重的问题,希望OneAPM能尽快解决,否则我可不敢放到生产环境里去测试。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这