FastCGI、Apache、Django 和 500 错误

0 投票
2 回答
5145 浏览
提问于 2025-04-16 02:27

我在使用Apache和FastCGI的时候遇到了500内部错误,今天花了一整天在找原因 :-/

/etc/apache2/vhost.d/mysite.conf

FastCGIExternalServer /home/me/web/mysite.fcgi -socket /home/me/web/mysite.sock
Listen 80
<VirtualHost *:80>
        ServerName os.me #That's my localhost machine
        DocumentRoot /home/me/web
        Alias /media/ /home/me/develop/projects/media

        <Directory "/home/me/web">
                AllowOverride All
                Allow from all
                Order allow,deny
        </Directory>

</VirtualHost>

/home/me/web/.htaccess

Options +Indexes +FollowSymlinks
AddHandler fastcgi-script .fcgi

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ mysite.fcgi/$1 [QSA,L]

/home/me/web/mysite.fcgi

#!/usr/bin/python
import sys, os

os.chdir("/home/me/develop/projects/mysite")
os.environ['DJANGO_SETTINGS_MODULE'] = "mysite.settings"

from django.core.servers.fastcgi import runfastcgi
runfastcgi(method="threaded",daemonize="false")

/var/log/apache2/error_log

...    
[Sat Aug 07 01:41:13 2010] [error] [client 127.0.0.1] (2)No such file or directory: FastCGI: failed to connect to server "/home/me/web/mysite.fcgi": connect() failed
[Sat Aug 07 01:41:13 2010] [error] [client 127.0.0.1] FastCGI: incomplete headers (0 bytes) received from server "/home/me/web/mysite.fcgi"

执行.fcgi文件时(它像网页一样正常工作,状态是“200 OK”,并且显示得也没问题):

me@os ~/web $ python mysite.fcgi 
WSGIServer: missing FastCGI param REQUEST_METHOD required by WSGI!
WSGIServer: missing FastCGI param SERVER_NAME required by WSGI!
WSGIServer: missing FastCGI param SERVER_PORT required by WSGI!
WSGIServer: missing FastCGI param SERVER_PROTOCOL required by WSGI!
Status: 200 OK
Content-Type: text/html
...

2 个回答

1

感谢#django的IRC频道的帮助(特别是zk)。

FastCGIExternalServer /home/me/web/mysite.fcgi -socket /home/me/web/mysite.sock

必须改成这样(因为apache应该自己启动fcgi进程):

FastCGIServer /home/me/web/mysite.fcgi -socket /home/me/web/mysite.sock

撰写回答