草庐IT

php - 在 PHP 中写入 STDERR 的内容去哪里了?

coder 2024-04-27 原文

据我了解,如果未设置 error_log 配置指令,则会将错误发送到 SAPI 错误记录器。例如,它是 Apache 中的错误日志或 CLI 中的 stderr。

因此,如果我从命令行运行脚本,则会直接显示错误(除非重定向)。如果我从 cron 运行脚本,错误将通过电子邮件发送给 cron 作业所有者。那么,如果我将电子邮件通过管道传输到脚本会怎样?

我刚开始编写脚本来处理退回邮件。我读过如果脚本输出任何东西,它会反弹回发件人。我不确定这是否适用于所有输出或仅适用于 STDOUT。还是 CLI 中的 STDERR 等于 STDOUT?

如果我将 error_log 配置指令设置到一个文件,我可以使用 trigger_errorerror_log 函数安全地输出错误消息而不发送退回给发件人?

由于脚本正在处理退回邮件,我真的很想避免退回给发件人。我想这可能会导致无限循环。由于错误日志位于另一个目录中,并且路径设置在包含文件中,因此在我设置配置指令之前,可能会出现一些错误。在脚本的最顶部使用 ini_set('error_log', 'syslog') 然后尽快将其更改为我的文件是否是个好主意?

最佳答案

当使用 CLI 时,stdoutstderr 都去同一个地方。对于 cron,输出通过电子邮件发送给 cron 作业所有者。对于命令行,输出被发送到终端。当将一个程序的输出传递给另一个程序(通过管道)时,输出返回到第一个程序。它的作用取决于程序。

在使用 CLI 时指定错误位置的最简单方法是在命令行上指定它。因此,如果通过管道将电子邮件发送到脚本,您可以使用以下内容:

| /usr/bin/php /path/to/script/script.php 2> /path/to/log/error.log

数字 2stderr 的文件句柄,> 将它重定向到指定的文件。

PHP 配置指令

至于不同的 PHP 配置指令,它们在 CLI 中的行为确实不同。显然,在某些版本/系统上存在错误,无论配置设置如何,错误都不会写入日志。

以下是在我的系统(Centos 6 上的 PHP 5.3)上使用 CLI 进行测试的结果:

  • 如果log_errors 打开,将display_errors 设置为0 不会停止显示错误。错误与 stdout 相同,除非在命令行上重定向。
  • 如果 log_errors off 并且 display_errors off,则不会报告任何错误。
  • 如果log_errors 打开 并且error_log 被设置为一个文件(具有适当的权限),则错误会转到该文件。
  • 如果 log_errors on 并且 error_log 设置为 'syslog',则错误会转到/var/日志/消息。
  • 如果 log_errors on 并且 display_errors on,将输出两条错误消息:一 strip 有 'PHP ' 前缀和一个不带前缀。
  • 我能看到将 display_errors 设置为 1 和将其设置为 'stderr' 之间的唯一区别是前者打印了额外的一行休息。

请注意,我只在命令行测试了不同的配置指令,而不是 cron 或通过管道传输到另一个程序。我想结果会是一样的,因为它们都是 CLI。唯一的区别是 stdout 的位置。

备选

与其担心什么输出可能返回给发件人,您可以允许消息进入邮箱。然后使用 PHP imap阅读邮件的功能。 PHP 脚本可以作为 cron 作业运行,然后任何错误消息都会发送给 cron 作业所有者。

关于php - 在 PHP 中写入 STDERR 的内容去哪里了?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17485430/

有关php - 在 PHP 中写入 STDERR 的内容去哪里了?的更多相关文章

  1. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  2. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

  3. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  4. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  5. ruby - Ruby 是否使用 $stdout 来写入 puts 和 return 的输出? - 2

    我想知道Ruby用来在命令行打印这些东西的输出流:irb(main):001:0>a="test"=>"test"irb(main):002:0>putsatest=>nilirb(main):003:0>a=>"test"$stdout是否用于irb(main):002:0>和irb(main):003:0>?而且,在这两次调用之间,$stdout的值是否有任何变化?另外,有人能告诉我打印/写入这些内容的Ruby源代码吗? 最佳答案 是的。而且很容易向自己测试/证明。在命令行试试这个:ruby-e'puts"foo"'>test.

  6. ruby - 如何使用 Selenium Webdriver 根据 div 的内容执行操作? - 2

    我有一个使用SeleniumWebdriver和Nokogiri的Ruby应用程序。我想选择一个类,然后对于那个类对应的每个div,我想根据div的内容执行一个Action。例如,我正在解析以下页面:https://www.google.com/webhp?sourceid=chrome-instant&ion=1&espv=2&ie=UTF-8#q=puppies这是一个搜索结果页面,我正在寻找描述中包含“Adoption”一词的第一个结果。因此机器人应该寻找带有className:"result"的div,对于每个检查它的.descriptiondiv是否包含单词“adoption

  7. ruby - 在 ruby​​ 中生成一个进程,捕获 stdout,stderr,获取退出状态 - 2

    我想从ruby​​rake脚本运行一个可执行文件,比如foo.exe我希望将foo.exe的STDOUT和STDERR输出直接写入我正在运行rake任务的控制台.当进程完成时,我想将退出代码捕获到一个变量中。我如何实现这一目标?我一直在玩backticks、process.spawn、system但我无法获得我想要的所有行为,只有部分更新:我在Windows上,在标准命令提示符下,而不是cygwin 最佳答案 system获取您想要的STDOUT行为。它还返回true作为零退出代码,这可能很有用。$?填充了有关最后一次system调

  8. Ruby:写入 stdin 并从 stdout 读取? - 2

    我正在编写一个ruby​​程序,它应该执行另一个程序,通过stdin向它传递值,从它的stdout读取响应,然后打印响应。这是我目前所拥有的。#!/usr/bin/envrubyrequire'open3'stdin,stdout,stderr=Open3.popen3('./MyProgram')stdin.puts"helloworld!"output=stdout.readerrors=stderr.readstdin.closestdout.closestderr.closeputs"Output:"puts"-------"putsoutputputs"\nErrors:"p

  9. Ruby -> 写入二维数组 - 2

    我正在处理http://prepwork.appacademy.io/mini-curriculum/array/中概述的数组问题我正在尝试创建函数my_transpose,它接受一个矩阵并返回其转置。我对写入二维数组感到很困惑!这是一个代码片段,突出了我的困惑。rows=[[0,1,2],[3,4,5],[6,7,8]]columns=Array.new(3,Array.new(3))putscolumns.to_s#Outputisa3x3arrayfilledwithnilcolumns[0][0]=0putscolumns.to_s#Outputis[[0,nil,nil],[

  10. ruby - 如何在ruby中提取方括号内的内容 - 2

    我正在尝试提取方括号内的内容。到目前为止,我一直在使用它,它有效,但我想知道我是否可以直接在正则表达式中使用某些东西,而不是使用这个删除功能。a="Thisissuchagreatday[coolawesome]"a[/\[.*?\]/].delete('[]')#=>"coolawesome" 最佳答案 差不多。a="Thisissuchagreatday[coolawesome]"a[/\[(.*?)\]/,1]#=>"coolawesome"a[/(?"coolawesome"第一个依赖于提取组而不是完全匹配;第二个利用前瞻和

随机推荐