. 就普通的反向代理来讲 Nginx的配置还是比较简单的,如: location ~ /* { proxy_pass http://127.0.0.1:8008; } 或者可以 location / { proxy_pass http://127.0.0.1:8008; } Apache2的反向代理的配置是: ProxyPass /ysz/ http://localhost:8080/ 然而,如果要配置一个相对复杂的反向代理 Nginx相对Apache2就要麻烦一些了 比如,将url中以/wap/开头的请求转发到后台对应的某台server上 可以再Nginx里设置一个变量,来临时保存/wap/后面的路径信息 location ^~ /wap/ { if ($request_uri ~ /wap/(\d+)/(.+)) { set $bucketid $1; set $params $2; } proxy_pass http://mx$bucketid.test.com:6601/$params; } 也可以首先rewrite一下,然后再代理: location ^~ /wap/{ rewrite /wap/(\d+)/(.+) /$2?$args break; proxy_pass http://mx$1.test.com:6601; } 或者 location ~* /wap/(\d+)/(.+) { proxy_pass http://mx$1.test.com:6601/$2?$args; } 注意上面最后的?$args,表明把原始url最后的get参数也给代理到后台 如果在proxy_pass中使用了变量(不管是主机名变量$1或后面的$2变量),则必须得加这段代码 但如果pass_proxy后没用任何变量,则不需要加,它默认会把所有的url都给代理到后台,如: location ~* /wap/(\d+)/(.+) { proxy_pass http://mx.test.com:6601; } 上面的proxy_pass配置,涉及到一个使用动态主机名的问题 参见http://www.tech126.com/?p=151 而Apache2相对就简单多了: ProxyPassMatch ^/wap/(.*)$ http://192.168.132.147/$1 if ($host ~* www.(.*)){ set $host_without_www $1; rewrite (.*)$ http://$host_without_www/www$1; } (责任编辑:IT) |