zoukankan      html  css  js  c++  java
  • 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看是否正确。如果有什么错误的话,修正即可。
  • 相关阅读:
    正则表达式(含递归用法)
    hive tricks
    树的数据结构
    基本排序算法
    佛祖保佑永无BUG
    客户问:“能再便宜点吗”,90%的销售顾问都回答错了?
    AutoMapper的介绍与使用(二)
    AutoMapper的介绍与使用(一)
    hasattr()、getattr()、setattr()函数的使用
    类与对象-内存存储形态
  • 原文地址:https://www.cnblogs.com/cosiray/p/2405236.html
Copyright © 2011-2022 走看看