千家信息网

Nginx中的proxy_pass怎么使用

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要介绍了Nginx中的proxy_pass怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Nginx中的proxy_pass怎么使用文章都会有所收获,下面
千家信息网最后更新 2025年02月02日Nginx中的proxy_pass怎么使用

这篇文章主要介绍了Nginx中的proxy_pass怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Nginx中的proxy_pass怎么使用文章都会有所收获,下面我们一起来看看吧。

一、proxy_pass的nginx官方指南

nginx中有两个模块都有proxy_pass指令。

ngx_http_proxy_module的proxy_pass:

语法: proxy_pass URL;场景: location, if in location, limit_except说明: 设置后端代理服务器的•协议(protocol)和地址(address),以及location中可以匹配的一个可选的URI。协议可以是"http"或"https"。地址可以是一个域名或ip地址和端口,或者一个 unix-domain socket 路径。  详见官方文档: http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_passURI的匹配,本文第四部分•重点讨论。

ngx_stream_proxy_module的proxy_pass:

语法: proxy_pass address;场景: server说明: 设置后端代理服务器的地址。这个地址(address)可以是一个域名或ip地址和端口,或者一个 unix-domain socket路径。  详见官方文档: http://nginx.org/en/docs/stream/ngx_stream_proxy_module.html#proxy_pass

二、两个proxy_pass的关系和区别

在两个模块中,两个proxy_pass都是用来做后端代理的指令。

ngx_stream_proxy_module模块的proxy_pass指令只能在server段使用使用, 只需要提供域名或ip地址和端口。可以理解为端口转发,可以是tcp端口,也可以是udp端口。

ngx_http_proxy_module模块的proxy_pass指令需要在location段,location中的if段,limit_except段中使用,处理需要提供域名或ip地址和端口外,还需要提供协议,如"http"或"https",还有一个可选的uri可以配置。

三、proxy_pass的具体用法

ngx_stream_proxy_module模块的proxy_pass指令

server {   listen 127.0.0.1:12345;   proxy_pass 127.0.0.1:8080;}server {   listen 12345;   proxy_connect_timeout 1s;   proxy_timeout 1m;   proxy_pass example.com:12345;}server {   listen 53 udp;   proxy_responses 1;   proxy_timeout 20s;   proxy_pass dns.example.com:53;}server {   listen [::1]:12345;   proxy_pass unix:/tmp/stream.socket;}

ngx_http_proxy_module模块的proxy_pass指令

server {   listen      80;   server_name www.test.com;   # 正常代理,不修改后端url的   location /some/path/ {       proxy_pass http://127.0.0.1;   }   # 修改后端url地址的代理(本例后端地址中,最后带了一个斜线)   location /testb {       proxy_pass http://www.other.com:8801/;   }   # 使用 if in location   location /google {       if ( $geoip_country_code ~ (RU|CN) ) {           proxy_pass http://www.google.hk;       }   }   location /yongfu/ {       # 没有匹配 limit_except 的,代理到 unix:/tmp/backend.socket:/uri/       proxy_pass http://unix:/tmp/backend.socket:/uri/;;       # 匹配到请求方法为: PUT or DELETE, 代理到9080       limit_except PUT DELETE {           proxy_pass http://127.0.0.1:9080;       }   }}

四、proxy_pass后,后端服务器的url(request_uri)情况分析

server {   listen      80;   server_name www.test.com;   # 情形A   # 访问 http://www.test.com/testa/aaaa   # 后端的request_uri为: /testa/aaaa   location ^~ /testa/ {       proxy_pass http://127.0.0.1:8801;   }      # 情形B   # 访问 http://www.test.com/testb/bbbb   # 后端的request_uri为: /bbbb   location ^~ /testb/ {       proxy_pass http://127.0.0.1:8801/;   }   # 情形C   # 下面这段location是正确的   location ~ /testc {       proxy_pass http://127.0.0.1:8801;   }   # 情形D   # 下面这段location是错误的   #   # nginx -t 时,会报如下错误:   #   # nginx: [emerg] "proxy_pass" cannot have URI part in location given by regular   # expression, or inside named location, or inside "if" statement, or inside   # "limit_except" block in /opt/app/nginx/conf/vhost/test.conf:17   #   # 当location为正则表达式时,proxy_pass 不能包含URI部分。本例中包含了"/"   location ~ /testd {       proxy_pass http://127.0.0.1:8801/;   # 记住,location为正则表达式时,不能这样写!!!   }   # 情形E   # 访问 http://www.test.com/ccc/bbbb   # 后端的request_uri为: /aaa/ccc/bbbb   location /ccc/ {       proxy_pass http://127.0.0.1:8801/aaa$request_uri;   }   # 情形F   # 访问 http://www.test.com/namea/ddd   # 后端的request_uri为: /yongfu?namea=ddd   location /namea/ {       rewrite    /namea/([^/]+) /yongfu?namea=$1 break;       proxy_pass http://127.0.0.1:8801;   }   # 情形G   # 访问 http://www.test.com/nameb/eee   # 后端的request_uri为: /yongfu?nameb=eee   location /nameb/ {       rewrite    /nameb/([^/]+) /yongfu?nameb=$1 break;       proxy_pass http://127.0.0.1:8801/;   }   access_log /data/logs/www/www.test.com.log;}server {   listen      8801;   server_name www.test.com;      root        /data/www/test;   index       index.php index.html;   rewrite ^(.*)$ /test.php?u=$1 last;   location ~ \.php$ {       try_files $uri =404;       fastcgi_pass unix:/tmp/php-cgi.sock;       fastcgi_index index.php;       include fastcgi.conf;   }   access_log /data/logs/www/www.test.com.8801.log;}

文件: /data/www/test/test.php

echo '$_SERVER[REQUEST_URI]:' . $_SERVER['REQUEST_URI'];

通过查看 $_SERVER[‘REQUEST_URI’] 的值,我们可以看到每次请求的后端的request_uri的值,进行验证。

关于"Nginx中的proxy_pass怎么使用"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"Nginx中的proxy_pass怎么使用"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。

地址 情形 端口 代理 指令 模块 端的 两个 域名 官方 服务器 知识 服务 内容 场景 文档 正则 篇文章 表达式 语法 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 苏州物流软件开发需要多少钱 七煌原初上海网络技术有限公司 软件开发人员外派方案 会员管理系统服务器版 软件开发比赛现场侧记 数据库系统原理作业二 宝山区智能软件开发售后服务 水电能耗分析数据库 王者服务器不同可以单挑吗 0a服务器 stata 选取数据库 amp网络安全 京口区森淼网络技术服务工作室 楚雄服务器上门回收中心 科蓝软件数据库泸州银行 安卓服务器监控软件 网络安全与黑客攻防宝典 网络安全加固靶机方法 渭南市第六届国家网络安全宣传周 深圳市丰巢网络技术有限 云南统一软件开发品质保障 万方数据库的论文怎么下载 手机赌博软件开发多少钱 无法建立于服务器的安全连接 工业网络安全运维攻略 idc服务器销售 读书郎数据库下载失败 四川软件开发项目费用测算 数据库如何使2表结构一样 网络安全事故可能导致的危害英文
0