我得到
当我打http://ec2-X-YZ-ABC-EFG.compute-1.amazonaws.com/admin
时。
我非常确定我的Django应用程序没有问题,因为该应用程序为空。我只是使用django-admin startproject tempo
进行了此更改– ALLOWED_HOSTS = ['*']
来创建应用程序,以便它接受来自任何IP的请求。
由于这是一个开发服务器,不包含任何数据,因此我已允许来自任何主机的请求。这是我的入站规则,
Ports Protocol Source
80 tcp 0.0.0.0/0, ::/0
22 tcp 0.0.0.0/0, ::/0
443 tcp 0.0.0.0/0, ::/0
这是我的/etc/nginx/sites-enabled/tempo
upstream tempo-server {
server unix:///home/ubuntu/tempo/tempo.sock;
}
server {
error_log /var/log/nginx/tempo/error.log;
access_log /var/log/nginx/tempo/access.log;
listen 80;
server_name X.YX.ABC.DEF;
location = /media/ {
root /home/ubuntu/tempo/media;
}
location / {
include /etc/uwsgi/sites/uwsgi_params;
uwsgi_pass tempo-server;
}
}
这是我的uwsgi.ini
文件
[uwsgi]
chdir = /home/ubuntu/tempo
module = tempo.wsgi
home = /home/ubuntu/seatr/venv-seatr
master = true
processes = 10
socket = /home/ubuntu/tempo/tempo.sock
chmod-socket = 777
vacuum = true
此外,uwsgi开头没有错误,.sock文件也已成功创建。
nginx error.log
显示:
2019/04/04 20:03:48 [error] 30261#30261: *9 upstream prematurely closed connection while reading response header from upstream, client: 129.219.8.129, server: X.YZ.ABC.DEF, request: "GET /admin HTTP/1.1", upstream: "uwsgi://unix:///home/ubuntu/tempo/tempo.sock:", host: "ec2-X-YZ-ABC-DEF.compute-1.amazonaws.com"
PS:启用我的网站(软链接)仅包含此tempo
文件,可用的sites包含几个文件。
我已经在多个地方读过这个问题,但没有答案:
答案 0 :(得分:0)
该死我的 uwsgi_params 文件完全为空。结果, nginx 无法发送“ REQUEST_METHOD ”之类的参数,从而导致上述错误。
我的 uwsgi_params 文件如下:
uwsgi_param QUERY_STRING $query_string;
uwsgi_param REQUEST_METHOD $request_method;
uwsgi_param CONTENT_TYPE $content_type;
uwsgi_param CONTENT_LENGTH $content_length;
uwsgi_param REQUEST_URI $request_uri;
uwsgi_param PATH_INFO $document_uri;
uwsgi_param DOCUMENT_ROOT $document_root;
uwsgi_param SERVER_PROTOCOL $server_protocol;
uwsgi_param HTTPS $https if_not_empty;
uwsgi_param REMOTE_ADDR $remote_addr;
uwsgi_param REMOTE_PORT $remote_port;
uwsgi_param SERVER_PORT $server_port;
uwsgi_param SERVER_NAME $server_name;