1

你好,

我在 Oracle64 位(Red Hat 克隆)上运行 apache 2.2.3,但遇到了问题。我有一个使用 MIME::Lite 通过 sendmail 发送邮件的程序(我很抱歉,不确定我正在运行什么版本的 sendmail 或 mod_perl,尽管我相信 sendmail 部分与您稍后会看到的无关)

有时,apache 会出现段错误 (11),然后深入研究 MIME::Lite 模块,我发现它位于以下行:

open SENDMAIL, "|$sendmailcmd" or Carp::croak "open |$sendmailcmd: $!\n";  (this is in MIME::Lite)

现在,人们会自动怀疑 sendmail,但如果我使用同一行来使用 /bin/cat(如图所示):

open SENDMAIL, "|/bin/cat" 

apache仍然有段错误。

我将 strace 附加到 apache 进程并看到以下内容:(当它不崩溃时)

12907 write(2, "SENDMAIL send_by_sendmail 1\n", 28) = 28
12907 write(2, "SENDMAIL /usr/lib/sendmail -t -o"..., 40) = 40
12907 pipe([24, 26])                    = 0
12907 pipe([28, 29])                    = 0
12907 clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD,     child_tidptr=0x2b4bcbbd75d0) = 13186

注意“SENDMAIL sent_by_sendmail”是我的评论。您可以清楚地看到管道打开。当它确实崩溃时,您将看到以下内容:

10805 write(2, "SENDMAIL send_by_sendmail (for y"..., 40) = 40
10805 --- SIGSEGV (Segmentation fault) @ 0 (0) ---

现在注意它从不管道。我已经尝试过 GDB,但它并没有真正向我展示任何东西。

最后,我编写了一个简单的程序来运行 mod_perl 和常规 cgi:

 print header();
 print "test";

 open SENDMAIL, "|/bin/cat" or Carp::croak "open |sendmailcmd: $!\n";
 print SENDMAIL "foodaddy";
 close SENDMAIL;
 print "test done <br/>";

在 mod_perl 下它已成功崩溃。

我的分析告诉我它与尝试打开文件句柄有关,管道函数返回错误或损坏的文件句柄。

我还将文件描述符限制增加到 2048,没有骰子。

有人对我应该看哪里有任何想法吗?有什么想法吗?

我很感激帮助

4

2 回答 2

0

我只是花了很长时间追踪一个以相同症状开始的问题。我最终发现 Test::More 不能很好地与 mod_perl 配合使用。从我的代码中删除这个模块似乎已经解决了这个问题(到目前为止!)。我没有更深入地了解这一点,但我怀疑问题实际上在于 Test::Builder。

于 2011-07-22T08:13:59.017 回答
0

我设法只治疗症状,而不是原因。当在包级别使用全局/包范围变量时,我碰巧遇到了这个问题,在 perl 对象实例中使用,只要我将它们作为对象属性而不是作为自动默认 perl 变量范围传递,我就停止体验 perl 分段突然出现故障。

于 2020-12-07T17:17:42.207 回答