我通过unix socket通过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配置来实现这一目标?
答案 0 :(得分:1)
一种方法是使用rewrite ... break
,例如:
location / {
try_files $uri @proxy;
}
location @proxy {
rewrite ^ /demo$uri break;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://django_app_server;
}
有关详细信息,请参阅this document。