2016-03-25 114 views
2

我正在通过Unix套接字通过gunicorn Django应用程序,我有我的nginx的配置看起来像这样:如何更改nginx proxy_pass中的request_uri?

当前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上运行插座在这里,让我们说,如果它是在本地主机上运行,​​然后它有一个网址,它看起来像:

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

这本来是很容易的,如果我将本地主机的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

无论上游连接如何(TCP或UNIX域套接字),此配置* proxy_pass http:// django_app_server/demo /; *看起来都是有效的。在这种情况下,你能在日志中看到什么? – Anatoly

回答

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