【发布时间】:2016-07-13 07:56:48
【问题描述】:
我正在通过 unix 套接字通过 gunicorn 运行 django 应用程序,我的 nginx 配置如下所示:
当前 NGINX 配置文件:
upstream django_app_server {
server unix:/django/run/gunicorn.sock fail_timeout=0;
}
server{
listen 80;
server_name demo.mysite.com;
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
if (!-f $request_filename) {
proxy_pass http://django_app_server;
break;
}
}
}
所以我的 django 在这里运行在 unix 套接字上,假设它在 localhost 上运行,那么它的 url 看起来像:
http://127.0.0.1:8000/demo/app1
http://127.0.0.1:8000/demo/notifications
主要目标
所以我想做的是,当有人访问http://demo.mysite.com/app1 时,他们可以通过代理访问网址:http://127.0.0.1:8000/demo/app1
如果我在 localhost tcp 端口上运行 django 会非常容易,而且我可以很容易地做到这一点,并且对我有用:
server{
listen 80;
server_name demo.mysite.com;
location / {
proxy_pass http://127.0.0.1:8000/demo/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
如何使用我当前的 nginx 配置来实现这一点?
【问题讨论】:
-
此配置 proxy_pass http://django_app_server/demo/; 无论上游连接如何(TCP 或 UNIX 域套接字)看起来都有效。在这种情况下,您可以在日志中看到什么?
标签: sockets mod-rewrite nginx rewrite gunicorn