千家信息网

Nginx中的proxy_pass怎么使用

发表于:2025-11-12 作者:千家信息网编辑
千家信息网最后更新 2025年11月12日,这篇文章主要介绍了Nginx中的proxy_pass怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Nginx中的proxy_pass怎么使用文章都会有所收获,下面
千家信息网最后更新 2025年11月12日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安全错误 数据库的锁怎样保障安全 TCGA数据库临床数据读取 璧山区软件开发招聘兼职吗 长春智能网络技术质量服务 苏州运营网络技术哪家好 通过观看网络安全上网教育视频 广东正规软件开发定制 web应用前端机指网站服务器吗 在哪可以找到迷你世界的服务器 服务器授权注册是什么意思 专科学网络安全好吗 qq飞车与服务器断开连接 数据库字符编码 计算机网络技术资料文章 数据库设计必读 中国人事人才网数据库 供电公司网络安全发言 浪潮服务器没有网络 网络安全手抄报空白处怎么画 如何采集服务器硬件信息 网站服务器怎么更换 鄂尔多斯 软件开发 服务器授权注册是什么意思 上海服务器代工 性价比高的服务器硬盘 服务器配置要考虑几兆带宽 梅州软件开发费用情况 有什么网络技术在家就能工作的 安卓平板应用软件开发 湖北web前端软件开发价格表 方舟生存进化服务器弹出回主界面
0