博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Premature end of script headers 的原因
阅读量:5817 次
发布时间:2019-06-18

本文共 1348 字,大约阅读时间需要 4 分钟。

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

你可能感兴趣的文章
开源 免费 java CMS - FreeCMS1.2-标签 infoSign
查看>>
开源 免费 java CMS - FreeCMS1.9 移动APP生成栏目列表数据
查看>>
虚拟机新增加硬盘,不用重启读到新加的硬盘
查看>>
Java IO流详尽解析
查看>>
邮件服务系列之四基于虚拟用户的虚拟域的邮件系统(安装courier-authlib以及部分配置方法)...
查看>>
Linux VSFTP服务器
查看>>
DHCP中继数据包互联网周游记
查看>>
Squid 反向代理服务器配置
查看>>
Java I/O操作
查看>>
Tomcat性能调优
查看>>
项目管理心得
查看>>
Android自学--一篇文章基本掌握所有的常用View组件
查看>>
灰度图像和彩色图像
查看>>
通过vb.net 和NPOI实现对excel的读操作
查看>>
TCP segmentation offload
查看>>
java数据类型
查看>>
数据结构——串的朴素模式和KMP匹配算法
查看>>
FreeMarker-Built-ins for strings
查看>>
验证DataGridView控件的数据输入
查看>>
POJ1033
查看>>