FastCGI,Apache,Django和500错误

时间:2010-08-06 23:01:24

标签: python django apache fastcgi

我在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 /日志/ 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文件(它作为html页面获得状态“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 个答案:

答案 0 :(得分:1)

答案 1 :(得分: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