在本教程中,我将向您演示如何使用 OpenResty XRay 快速定位最热的 Lua 代码路径。这些代码路径可能占用了您 OpenResty 或 Nginx 应用程序中的大部分 CPU 时间。

问题: 高 CPU 使用率

首先运行 top 命令,检查目标服务器上的 CPU 使用情况。如您所见,一个 Nginx 工作进程占用了将近 100% 的 CPU 核心资源。

Screenshot

使用 OpenResty XRay 的引导式分析功能定位最热的 Lua 代码路径

现在让我们来使用 OpenResty XRay 检查这个未经修改的进程。我们可以对它进行实时分析,找出问题所在。

在浏览器中打开 OpenResty XRay web 控制台。

Screenshot

如果您还没有登录,需要先登录。

Screenshot

输入您的账户名,也就是您的电子邮件地址。

Screenshot

输入您的密码。

Screenshot

点击“登录”。

Screenshot

确保您正在分析正确的服务器。

Screenshot

进入引导式分析页面。

Screenshot

这里可以看到您能够分析的不同类型的问题。

Screenshot

选择 High CPU 问题类型。

Screenshot

点击“下一步”。

Screenshot

选择应用程序。

Screenshot

选择消耗 97% CPU 资源的进程。

Screenshot

确保应用程序的类型是正确的。通常默认值就是正确的。

Screenshot

OpenResty XRay 可以同时分析多种语言级别。这里我们保持 Lua 和 C 都选中的状态。

Screenshot

还可以设置最大分析时间。这里保留默认值 300 秒。

Screenshot

开始分析。

Screenshot

系统将持续进行多轮分析。现在正在执行第一轮分析。

Screenshot

第一轮分析已经完成,现在已经进入第二轮了。对于今天这种情况,一轮分析已经足够。

Screenshot

停止分析。

Screenshot

可以看到自动创建了一个报告。

Screenshot

报告显示了占用最多 CPU 时间的最热 Lua 代码路径。

Screenshot

点击这里查看更多细节。

Screenshot

这里有一个 CPU 火焰图,最热的代码路径用红色标识出来。

Screenshot

最热的 Lua 代码路径涉及 MD5 计算函数的调用。

Screenshot

之后的调用函数都来自目标应用程序的业务代码。

Screenshot

gen_order_md5 Lua 函数开始,在应用程序业务代码中找到精确的源代码行。

Screenshot

当我们将鼠标悬停在函数的绿色框上时,可以在出现的提示中看到 Lua 源文件 processor.lua 的完整路径。

Screenshot

源代码行号是 29。

Screenshot

点击图标复制这个函数的完整 Lua 源文件路径。

Screenshot

使用 VI 编辑器,将我们刚刚复制的代码路径粘贴到这里,查看相应的业务 Lua 代码。您可以使用任何您喜欢的编辑器。

Screenshot

从之前的报告中,我们知道代码在第 29 行。

Screenshot

可以看到这行 Lua 源代码确实包含了一个循环的 md5 计算。

Screenshot

它也在报告中显示的 gen_order_md5 函数中。

Screenshot

全自动分析与报告

OpenResty XRay 也可以自动地监控在线进程,并显示分析报告。

Screenshot

进入 Insights 页面。

Screenshot

您可以在 Insights 页面中找到以日和周为周期生成的报告。

Screenshot

而不是必须使用引导分析功能。当然,引导式分析对于应用程序开发和演示是很有用的。

Screenshot

OpenResty XRay 是一个基于我们自己的动态追踪技术开发的非侵入式诊断系统。它可以实时监控和扫描性能问题、行为问题和安全漏洞。

noninvasive-checkup.jpg

如果你喜欢这个教程,请订阅这个博客网站和我们的 YouTube 频道B 站频道。谢谢!

关于 OpenResty XRay

OpenResty XRay 是一个动态追踪产品,它可以自动分析运行中的应用程序,以解决性能问题、行为问题和安全漏洞,并提供可行的建议。在底层实现上,OpenResty XRay 由我们的 Y 语言驱动,可以在不同环境下支持多种不同的运行时,如 Stap+、eBPF+、GDB 和 ODB。

关于本文和关联视频

本文和相关联的视频都是完全由我们的 OpenResty Showman 产品从一个简单的剧本文件自动生成的。

关于作者

章亦春是开源 OpenResty® 项目创始人兼 OpenResty Inc. 公司 CEO 和创始人。

章亦春(Github ID: agentzh),生于中国江苏,现定居美国湾区。他是中国早期开源技术和文化的倡导者和领军人物,曾供职于多家国际知名的高科技企业,如 Cloudflare、雅虎、阿里巴巴, 是 “边缘计算“、”动态追踪 “和 “机器编程 “的先驱,拥有超过 22 年的编程及 16 年的开源经验。作为拥有超过 4000 万全球域名用户的开源项目的领导者。他基于其 OpenResty® 开源项目打造的高科技企业 OpenResty Inc. 位于美国硅谷中心。其主打的两个产品 OpenResty XRay(利用动态追踪技术的非侵入式的故障剖析和排除工具)和 OpenResty Edge(最适合微服务和分布式流量的全能型网关软件),广受全球众多上市及大型企业青睐。在 OpenResty 以外,章亦春为多个开源项目贡献了累计超过百万行代码,其中包括,Linux 内核、Nginx、LuaJITGDBSystemTapLLVM、Perl 等,并编写过 60 多个开源软件库。

关注我们

如果您喜欢本文,欢迎关注我们 OpenResty Inc. 公司的博客网站 。也欢迎扫码关注我们的微信公众号:

我们的微信公众号

翻译

我们提供了英文版原文和中译版(本文)。我们也欢迎读者提供其他语言的翻译版本,只要是全文翻译不带省略,我们都将会考虑采用,非常感谢!