事务跟踪
事务跟踪对解决性能问题,获取您的应用如何工作的详细初级信息非常有用。
缓慢的HTTP调用被识别,并且数据库和外部调用都被聚合从而对其进行理解。
事务跟踪在默认情况下是禁用的。 在大型基础架构上,您最好只在几天内使用事务跟踪来收集信息,然后禁用它,因为这其中没有抽样且所有请求都会被处理。
您得等待10分钟才能让PM2收集足够的数据。
在io初始化时添加
启用:
禁用:
高级选项
您必须使用io初始化来自定义您的事务跟踪。
—trace
使用默认设置启用事务跟踪,因此在使用高级选项之前运行 —disable-trace
。
在该图下,您可以选择要在图上绘制哪些值:
- 该应用的 会告诉您一个普通用户可以依靠什么作为响应时间。
- 数据库延迟显示您在标准请求中消耗多少时间。
- 大部分时间消耗:整个应用在此路由上花费的总时间
- 最慢的路线:哪些路由花费最多的时间
- 调用次数:每条路由有多少个调用
一些事务具有相同的路径,但响应方式不同:路由上的一个禁止访问可以返回403,并且执行的操作与平时不同。 我们将这此称为 差异 :对于每条路径,我们记录5个最常用的差异,以便您在此查看。
我们来分析一个具体的差异:
- 中位数,最慢和最快的调用响应时间
- 有关调用的元数据
- 注册的子控制列表。 如果没有对外部 实体 进行调用,则此处不显示任何内容。 调用显示和信息取决于记录的堆栈。 关于数据库,您将可能看到数据库调用的情况。
然后,您可以点击另一个 variance (差异)来检查行为不同的原因和方式
在hood下
如果存在于您的应用中,PMX将包装在模块之下
express
version 4hapi
versions 8 - 13restify
versions 3 - 4koa
version v1.x- 出站HTTP请求使用
http
核心模块 mongodb-core
version 1 (used by mongoose)mysql
version ^2.9pg
version ^6.x
然后记录他们发出或接收的所有请求,发送给PM2进行汇总。对性能的影响应该会很低,因为除了包装模块和发送数据之外,您的进程中没有大量逻辑语言需要完成。
- 当被PM2接收时,事务会根据其路径汇总(因此没有query),例如:
/api/users/1
和/api/users/2
将被聚合在一起,因为PM2检测到1
和2
有标识符/api/users/search
和/api/users/1
不会被聚合在一起,因为search
不是一个标识符
- PM2使用多个正则表达式检测标识符:
- 带或不带破折号的UUID v1/v4 ()
- 任何数字 (
/\d+/
) - 数字和字幕的组合 (
/[0-9]+[a-z]+|[a-z]+[0-9]+/
):这个被mongo用于文件ID - 大多数SEO优化网页(文章,博客帖子…):
/((?:[0-9a-zA-Z]+[@-.][0-9a-zA-Z]+|[0-9a-zA-Z]+[@-.]|[@-_.][0-9a-zA-Z]+)+)/
- 此功能与其他模块有一些已知的问题:
request-promise
:清除节点缓存并请求一个新的干净版本的http
模块。 为了解决这个问题,需要request-promise
来获得正确包装的http
模块后再次请求http
。node-newrelic
:和我们一样工作,您可用此解决遇到的问题。
下一步
我们一直乐于帮您解决可能遇到的问题。搜索我们的文档或查看常见问题的答案。您也可以在我们的社区论坛发布问题或评论。您也可以看看我们在github中的帮助部分 https://github.com/keymetrics/keymetrics-support