首页 > 代码库 > 【Nginx】关于域名转发proxy_pass

【Nginx】关于域名转发proxy_pass

  在配置nginx的时候,有一个需求,访问m.XXX.com的时候,需要实际访问www.YYY.com/m,并且域名不能发生变化。

  达成这个需求有两种做法:

    第一种就是301跳转,使用rewrite来跳转域名,不过这样域名就会发生变化,与需求不符。

    第二种就是用proxy_pass跳转,只要指定跳转目的域名,就可以在访问的时候自动跳转访问目的域名,而且域名也不会发生变化。所以这里需要使用第二种方法。


  首先在/etc/nginx/conf.d/建立一个m.XXX.com.conf文件,内容为:

 1 server 2 { 3         listen 80; 4         server_name m.XXX.com; 5  6         location / 7         { 8             proxy_pass http://www.YYY.com/m/; 9         }10 }    

  这里要注意proxy_pass后面域名最后的"/",如果不添加,会跳转失败。

  然后在/etc/nginx/nginx.conf的http块内添加一行:

1 include /etc/nginx/conf.d/m.XXX.com.conf;

  然后就是重启nginx:

1 sudo /usr/nginx/nginx -s reload

  这样就可以在访问m.XXX.com的时候自动跳转到访问www.YYY.com/m了,而且域名不会发生改变。

  这里又出现了一个问题,静态资源访问不了,所以我们在m.XXX.com.conf里添加静态资源访问设置:

 1 server 2     { 3         listen 80; 4         server_name m.XXX.com; 5  6         location / 7         { 8             proxy_pass http://www.YYY.com/m/; 9         }10 11         location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css|html)$12         {13             root /home/YYY/java/apache-tomcat-6.0.41/webapps/ROOT/;14             expires      30d;15         }16     }

  当指定了静态资源的访问目录后,就能够访问到静态文件了。

  至此,需求已经解决!


  在测试后,还出现了一个问题,后台需要获取用户的信息,所以需要在m.XXX.com.conf的location内添加上下面的两行,用以修改请求头:

1 proxy_set_header Host $http_host;2 proxy_set_header X-Forward-For $remote_addr;

  按理说这样就可以了,可是却出现了"502 Bad Gateway"错误,如果将第一行给删去,则可以恢复正常访问页面,如果除去注释,错误又出现了。查询了很多办法,均无法解决这个问题,兹将次问题记下,待解决了补齐!

【Nginx】关于域名转发proxy_pass