Premature end of script headers 的原因

Premature,英文解释, 过早的。
Premature end of script headers 也就是cgi执行过早的结束了。通常这是因为CGI程序有问题,未能按照格式正确的打印完毕,就结束了。所以会报错。

但是 今天遇到一个很奇怪的问题。开发,测试环境中,某CGI运行正常,一到运营环境就报错:Premature end of script headers .

但是的逻辑就是,为什么程序没有变,但却运行突然出错了。而且一开始的时候,还能够运行。突然就报错。也没有人修改过程序,尝试重新编译,结果仍然一样报错。

后来查看cgi应用日志,发现打印了一串错误信息,报读取配置文件失败。

才恍然大悟。 cgi 在没有变更的情况下,突然无法执行的原因如下:

1 应用日志报 读取XX.conf配置文件失败。 因为之前配置文件一直读取正常,所以CGI也运行正常。
但是现在配置文件无法读取了,cgi打印了错误到页面上,此段代买存在一定的问题,导致页面无法现显示,报Premature end of script headers .

2 为什么conf文件突然无法显示了呢? 因为在suse服务器下,文件的权限默认都很少。 apache以nobody用户运行,本来没事。 因为文件数组也改成Nobody了。但是上服务器修改了某配置,保存。这配置文件编程了root ,导致该文件无法被以Nobody用户起的apache读取,报错。

而报错信息这一分支显然没有经过仔细的测试,存在问题。导致报Premature end of script headers。

所以,当程序都没有动过的时候,突然出现异常。我们就应该考虑,程序是否因为某种原因,走到了某一个特殊的分支,导致出错。此时,详细的应用日志,能给定位问题带来巨大的方便。

-------------------------------------

现状:

   当使用Apache(或其他web server,例如lighttpd),以及fastcgi(或cgi)等来部署rails或python等时,经常会出现以下错误:

     Premature end of script headers: dispatch.fcgi

解决方案:

本解决方案是基于Rails+Apache+fastcgi+debian,其他类似。

  • 检查dispatch.fcgi的用户或用户组,以及访问权限,至少定义为755.
  • 检查dispatch.fcgi的第一行的ruby编译器是否正确,很多人开发在windows平台上,而部署则在Linux/Unix平台上, 所以将#!C:/ruby.exe改为#  !/usr/bin/ruby。ruby具体在什么位置,输入whereis ruby即可。
  • 不能允许有打印的代码。例如在rails里,坚决不要将p 或puts写到代码里,这样会导致header破坏。其他语言看着办。
  • 如果以上方案均为解决,到dispatch所在的目录下运行 ./dispatch.fcgi看是否正确。如果有什么错误的话,修正即可。

转载于:https://www.cnblogs.com/cosiray/archive/2012/03/18/2405236.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值