Nginx服务器的反向代理proxy_pass配置方法讲解
来源:互联网 发布:比特币算法为谁服务 编辑:程序博客网 时间:2024/04/27 19:45
就普通的反向代理来讲
或者可以
也可以首先rewrite一下,然后再代理:
或者
注意上面最后的?$args,表明把原始url最后的get参数也给代理到后台
如果在proxy_pass中使用了变量(不管是主机名变量$1或后面的$2变量),则必须得加这段代码
但如果pass_proxy后没用任何变量,则不需要加,它默认会把所有的url都给代理到后台,如:
url的/问题
在nginx中配置proxy_pass时,当在后面的url加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;如果没有/,则会把匹配的路径部分也给代理走。
下面四种情况分别用http://192.168.1.4/proxy/test.html 进行访问。
第一种:
会被代理到http://127.0.0.1:81/test.html 这个url
第三种:
会被代理到http://127.0.0.1:81/ftlynx/test.html 这个url。
第四种情况(相对于第三种,最后少一个 / ):
会被代理到http://127.0.0.1:81/ftlynxtest.html 这个url
上面的结果都是本人结合日志文件测试过的。从结果可以看出,应该说分为两种情况才正确。即http://127.0.0.1:81 (上面的第二种) 这种和 http://127.0.0.1:81/.... (上面的第1,3,4种) 这种。
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;}而Apache2相对就简单多了:
ProxyPassMatch ^/wap/(.*)$ http://192.168.132.147/$1 if ($host ~* www.(.*)){ set $host_without_www $1; rewrite (.*)$ http://$host_without_www/www$1; }
url的/问题
在nginx中配置proxy_pass时,当在后面的url加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;如果没有/,则会把匹配的路径部分也给代理走。
下面四种情况分别用http://192.168.1.4/proxy/test.html 进行访问。
第一种:
location /proxy/ { proxy_pass http://127.0.0.1:81/;}
会被代理到http://127.0.0.1:81/test.html 这个url
第二种(相对于第一种,最后少一个 /)
location /proxy/ { proxy_pass http://127.0.0.1:81;}会被代理到http://127.0.0.1:81/proxy/test.html 这个url
第三种:
location /proxy/ { proxy_pass http://127.0.0.1:81/ftlynx/;}
会被代理到http://127.0.0.1:81/ftlynx/test.html 这个url。
第四种情况(相对于第三种,最后少一个 / ):
location /proxy/ { proxy_pass http://127.0.0.1:81/ftlynx;}
会被代理到http://127.0.0.1:81/ftlynxtest.html 这个url
上面的结果都是本人结合日志文件测试过的。从结果可以看出,应该说分为两种情况才正确。即http://127.0.0.1:81 (上面的第二种) 这种和 http://127.0.0.1:81/.... (上面的第1,3,4种) 这种。
0 0
- Nginx服务器的反向代理proxy_pass配置方法讲解
- Nginx服务器的反向代理proxy_pass配置方法讲解
- Nginx服务器的反向代理proxy_pass配置方法讲解
- nginx反向代理proxy_pass不配置URI引起的思考
- nginx proxy_pass 反向代理
- nginx proxy_pass 反向代理的用法
- nginx做反向代理proxy_pass,proxy_redirect的使用
- nginx反向代理(proxy_pass)tomcat导致session失效的问题解决
- nginx使用proxy_pass反向代理时,session丢失的问题
- nginx反向代理之proxy_pass指令
- nginx配置proxy_pass代理转发
- Nginx反向代理原理和配置的讲解
- Nginx的proxy_pass配置
- nginx反向代理原理和配置讲解
- nginx反向代理原理和配置讲解
- Nginx不同域名反向代理到另一台服务器 proxy_pass和$host
- 使用Nginx反向代理与proxy_cache缓存搭建CDN服务器的配置方法
- nginx服务器图片的反向代理和负载均衡配置
- 关于32位Linux系统内存溢出问题的情况及几种常见解决方法
- 【JavaScript】将方法从对象中解耦
- Linux下实现SSH免密码登录
- led显示屏扫描方式1/2、1/4、1/8 、/16
- InstallShield 2015 错误 Failed to verify digital signature of IsUiServices.dll
- Nginx服务器的反向代理proxy_pass配置方法讲解
- C++初始化列表的使用
- 函数式编程(二)
- ajax详解
- Windows下RSA密钥生成工具openssl
- SQLServer 重建索引前后对比
- Android手势识别01——基本手势的处理
- Vue动画 和 Vue路由
- 商品展示——实体类和适配器的创建