分析超时的 Perl CGI 脚本

Posted

技术标签:

【中文标题】分析超时的 Perl CGI 脚本【英文标题】:Profiling a Perl CGI script that times-out 【发布时间】:2013-12-23 07:54:24 【问题描述】:

我有一个 Perl CGI 应用程序有时会超时,导致它被 Apache 杀死,并且504 Gateway Time-out 错误被发送到浏览器。我正在尝试使用 NYTProf 分析此应用程序,但是我无法读取配置文件数据:

 $ nytprofhtml -f www/cgi-local/nytprof.out
Reading www/cgi-local/nytprof.out
Profile data incomplete, inflate error -5 ((null)) at end of input file, perhaps the process didn't exit cleanly or the file has been truncated  (refer to TROUBLESHOOTING in the documentation)

我正在使用sigexit=1NYTProf 选项。这是重现问题的最小 CGI 脚本:

#!/usr/bin/perl -d:NYTProf

sleep 1 while 1;

【问题讨论】:

【参考方案1】:

设置 sigexit=1 告诉 NYTProf 捕捉以下信号:

INT HUP PIPE BUS SEGV

但是,当您的 CGI 脚本超时时,Apache 会发送 SIGTERM。你需要抓住SIGTERM

sigexit=term

要在默认信号之外捕获SIGTERM,请使用:

sigexit=int,hup,pipe,bus,segv,term

【讨论】:

请更新答案,告诉我如何设置这些sigexit=int,hup,pipe,bus,segv,term 以及在哪里?例如:export NYTPROF=sigexit=1:file=nytprof.out 然后运行脚本。【参考方案2】:

CGI.pm 有一个debug mode,您可以使用它从命令行运行您的程序,并将您的 CGI 参数作为键/值对传递。

它还有另一个功能,您可以使用save your params to a file,然后稍后再读回该文件。

我所做的是添加代码以将参数保存到文件中,并通过浏览器运行我的程序。这也有助于我确保浏览器发送正确的数据。

然后我更改代码以从文件中读取参数,并根据需要经常运行它,直到我调试完所有其他内容。

一旦您在命令行中让程序运行到您满意的程度,您就可以通过 nytprof 运行它来找出一直占用的时间。

【讨论】:

以上是关于分析超时的 Perl CGI 脚本的主要内容,如果未能解决你的问题,请参考以下文章

如何从命令行测试Perl CGI脚本的文件上传?

Perl cgi 脚本无法读取与其父目录具有相同权限的目录

以管理员身份运行 cgi perl 脚本

Apache服务器中运行CGI程序的方法,文中以Perl脚本作为示例

为啥我的 Perl CGI 脚本找不到 Oracle DBD?

如何配置 Apache 2 以运行 Perl CGI 脚本?