百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

一次说清-Nginx反向代理及参数配置

off999 2025-02-15 00:38 107 浏览 0 评论

我们在配置服务时常常会用到Nginx来设置反向代理,虽然常用,但是我们真的了解各个参数的意思吗?

不如我们一起来看下吧。

1、反向代理

反向代理(reverse proxy)方式是指用代理服务器来接受Internet上的连接请求,然后将请求转发给内部网络中的上游服务器,并将从上游服务器上得到的结果返回给Internet上请求连接的客户端,此时代理服务器对外表现局势一个web服务器。

2、Nginx反向代理

Nginx的反向代理,当用户发送一个HTTP请求时,Nginx不会立刻转发到上游服务器,而是先把用户的请求(包括HTTP包体)完整地接收到Nginx所在的服务器的磁盘或内存中,然后再向上游服务器发起连接,把缓存的客户端请求转发到上游服务器。

优点:降低上游服务器的负载,尽量把压力放在Nginx服务器上

缺点:延长了一个请求的处理时间,并增加了用于缓存请求内容的内存和磁盘空间。

3、负载均衡的基本配置

3.1 upstream

语法:upstream name{......};

配置块:http

upstream块定义了一个上游服务器的集群,便于反向代理中的proxy_pass使用。

ini复制代码upstream backend {
	server backend1.example.com;
	server backend2.example.com;
	server backend3.example.com;
}
server {
	location / {
			proxy_pass http://backend;
	}
}

3.2 server

语法:server name[parameters];

配置块:upstream

server指定一台上游服务器的名字,该名字可以是域名、ip地址端口、UNIX句柄等,后面可跟参数:

.weight=number:设置向这台上游服务器转发的权重,默认是1。

.max_fails=number:该选项与fail_timeout配合使用,指在fail_timeout时间段内,如果向当前的上游服务器转发失败次数超过number,则认为在当前的fail_timeout时间段内这台上游服务器不可用。max_fail默认为1,如果设置为0,表示不检查失败次数。

.fail_timeout=time:fail_timeout表示该时间段内转发失败多少次后认为上游服务器暂时不可用,用于优化反向代理功能。它与向上游服务器建立连接的超时时间、读取上游服务器的响应超时时间等完全无关。默认为10s。

.down:表示所有的上游服务器永久下线,只在使用ip_hash配置项时才有用。

.backup:在使用ip_hash配置项时它是无效的。表示所在的上游服务器只是备份服务器,只有在所有的非备份上游服务器都失效后,才会向所在的上游服务器转发请求。

ini复制代码upstream backend {
    server backend1.example.com weight=5;
    server 127.0.0.1:8080 max_fails=3 fail_timeout=30s;
    server unix:/tmp/backend3;
}

3.3 ip_hash

语法:ip_hash;

配置块:upstream

ip_hash是某个用户的请求始终落在固定的一台上游服务器上。它根据用户端的ip计算出一个key,将key按照upstream集群里的上游服务器数量进行取模,然后以取模后的结果把请求转发到相应的上游服务器中,这样确保了同一个客户端的请求只会转发到指定的上游服务器中。

ip_hash与weight(权重)配置不可同时使用。如果upstream中一台服务器不能使用时,不能直接删除,而是使用down标识,来确保转发策略的一惯性。

ini复制代码upstream backend {
    ip_hash;
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com down;
    server backend4.example.com;
}

4、反向代理的基本配置

1、proxy_pass

语法:proxy_pass URL;

配置块:location、if

将当前请求反向代理到URL参数指定的服务器上,URL可以是主机名或IP地址+端口。

bash复制代码location / {
     proxy_pass http://localhost:8000/uri
}

默认情况下反向代理是不会转发请求中的Host头部的,如需转发需加上配置:proxy_set_header Host $host;

2、proxy_method

语法:proxy_method [
GET/POST/DELETE/UPDATE/......];

配置块:http、server、location

表示转发时的协议方法名。

ini复制代码proxy_method POST;

3、proxy_hide_header

语法:proxy_hide_header the_header;

配置块:http、server、location

Nginx将上游服务器的响应转发给客户端,但默认不会转发:Date、Server、X-Pad和X-Accel-*。使用proxy_hide_header后可以任意地指定哪些HTTP头部字段不能被转发。

4、proxy_pass_header

语法:proxy_pass_header the_header

配置块:http、server、location

与proxy_hide_header功能相反,将原来禁止转发的header设置为允许转发。

5、proxy_pass_request_body

语法:proxy_pass_requst_body on|off;

默认:proxy_pass_request_body on;

配置块:http、server、location

表示确定是否向上游服务器发送HTTP包体部分。

6、proxy_pass_request_headers

语法:
proxy_pass_request_headers on|off;

默认:
proxy_pass_request_headers on;

配置块:http、server、location

作用为确定是否转发HTTP头部

7、proxy_redirect

语法:proxy_redirect[default|off|redirect replacement];

默认:proxy_redirect default;

配置块:http、server、location

当上游服务器返回的响应是重定向或刷新(如301或302)请求时,proxy_redirect可以重设http头部的location或refresh字段。

bash复制代码proxy_redirect http://localhost:8000/two/  http://frontendone;

上述代码如果上游服务器返回302,location字段的URL是
http://localhost:8000/two/some/uri/ 转发给客户端的location就是:
http://frontendonesome/uri/

.replacement:可以省略replacement参数中的主机名部分,此时会用虚拟主机名称来填充。

.off:将使location或refresh字段维持不变。

.default:按照proxy_pass配置项和所属的location配置项重组发往客户端的location头部。

bash复制代码location one {
  proxy_pass http://upstream:port/two/;
  proxy_redirect default;
}
location one {
  proxy_pass http://upstream:port/two/;
  proxy_redirect http://upstream:port/two/one;
}

上述两种配置效果一样。

8、proxy_next_upstream

语法:proxy_next_upstream[error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off];

默认:proxy_next_upstream error timeout;

配置块:http、server、location

表示当向一台上游服务器转发请求出现错误时,继续换一台上游服务器处理这个请求。

proxy_next_upstream参数则说明在哪些情况下会继续选择下一台上游服务器转发请求:

.error:当向上游服务器发起连接、发送请求、读取响应时出错。

.timeout:发送请求或读取响应时发生超时。

.invalid_header:上游服务器发送的响应是不合法的。

.http_500:上游服务器返回的响应码是500。

.http_502:上游服务器返回的响应码是502。

.http_503:上游服务器返回的响应码是503。

.http_504:上游服务器返回的响应码是504。

·http_404:上游服务器返回的HTTP响应码是404。

.off:关闭proxy_next_upstream功能-出错就选择另一台上游服务器再次转发。

上述就是我整理的一些Nginx反向代理的参数信息,希望对大家有所帮助,谢谢。

相关推荐

微pe安装win10系统(微pe2.0装win10详细教程)
  • 微pe安装win10系统(微pe2.0装win10详细教程)
  • 微pe安装win10系统(微pe2.0装win10详细教程)
  • 微pe安装win10系统(微pe2.0装win10详细教程)
  • 微pe安装win10系统(微pe2.0装win10详细教程)
cpu坏了会无限重启吗(cpu坏了会无限重启吗为什么)

是的,这种情况一般多是CPU针脚有损坏,造成内存不能正确识别!现在的内存控制器一般集成在CPU所以容易出现这个问题!之前我在网上淘了一块二手CPU,安装好后无限重启,确定没有安装出错,拿到实体店也没有...

用户账户控制(关闭用户账户控制)

 选择此电脑,单击鼠标右键,点击管理,进入计算机管理界面,点击本地用户和组,点击用户,在右边会出现相应的用户设置窗口,在右边的窗口上选择名为Administrator的用户,右键单击Admi...

怎样取消电脑自动关机设置(电脑取消自动关机在哪里设置)

1、在电脑键盘里找到windows和R这两个键盘,找到之后,同时按住这两个键盘。2、按住了这两个组合键之后就将可以将电脑的命令窗口打开了。3、在命令窗口里面的打开一栏里输入shutdown-a这样的...

万界系统txt下载(万界系统林萧txt)

超级败家子,万界之大佬都是我儿子,类似的有系统的小说主角大多都能穿越万界穿越时空位面玩转次元位面次元位面主系统无限之时空大盗最强掠夺系统位面电梯我的房间有扇任意门大无限神戒《儒道至圣》《佛本是道》《...

腾讯qq密码怎么改(腾讯qq密码修改中心)

因腾讯视频是使用微信或者QQ帐号登录的,没有独立的腾讯视频账号密码,想修改登录密码,请通过QQ或者微信个人中心进行更改即可。QQ密码修改:进入手机QQ->左上角个人头像->设置->帐...

win10安全模式根本进不去(windows10安全模式进不去怎么办)

win10安全模式启动不了的解决教程:1、按下【win】+【R】,打开运行窗口,然后输入【msconfig】。点击确定。2、然后切换到【引导】界面。将【安全引导】和【最小】进行勾选,点击【确定】。3、...

win8激活密钥2025(win8激活密钥永久激活码)

1不存在永久激活密钥,但可以使用一些有效期长的密钥去激活Win10专业版。2Windows10的激活方式是基于数字权利,当你购买Windows10时,系统会将您电脑的硬件信息和购买记录绑定在一起...

windows远程桌面(远程桌面app安卓版)

要在WindowsServer2016上开启远程桌面服务,您可以按照以下步骤操作:1.**打开服务器管理器**:您需要登录到您的WindowsServer2016系统。2.**启用远程桌面...

网盘app下载安装(雀云网盘app下载安装)

因为这时的文件只是下载到云盘里,并没有下载到手机里,而在云盘里是不能执行安装程序的,需要把云盘里的安装包,下载到手机内存里面,才可以执行安装命令。现在相当于,你的快递已经在驿站签收了,随时都可以拿回来...

隐藏文件夹不显示(隐藏文件夹不显示出来)

如果,可能是文件被删除或移动到其他位置。隐藏文件是指在文件系统中设置了隐藏属性的文件,通过更改文件夹的设置可以显示或隐藏这些文件。如果文件夹显示隐藏文件的设置已经开启,但仍然找不到文件,可能是因为文件...

强制修改密码软件下载(强制密码修改器)

1.首先找回账户密码(适用于Android设备):如果您的设备与账户关联,可以访问账户的“找回密码”功能,通过重置密码来修改锁屏密码。2.使用其他登录方式(适用于iOS设备):如果您启用了Touch...

苹果ipad充不进电怎么办(苹果ipad充不进去电什么原因)

如果你发现你的iPad不能充电,那么你这样试一下,你看是不是充电的温度太低,你给他拿到一个比较温暖的房间里去,第2个就是你换一个充电器试一试,是不是那个充电器坏了,如果还不行的话,你可以把iPad重新...

无法正常启动0xc000005(无法正常启动你的电脑0xc0000001)

如果手机下载安装的第三方应用出现问题,无法正常使用,三星手机一般建议进行以下步骤排查及处理:1.关闭重新启动该应用。2.建议将此软件卸载重新安装尝试。3.更换其他版本尝试。4.更新下手机系统版本后安装...

无线网登录(无线网登录入口)

1.打开手机浏览器,访问192.168.0.1,输入用户名和密码就可以进入路由器管理界面。2.手机wifi连接路由器信号之后,会弹出对话框,需要输入用户名和密码(有的路由器只需要密码)。3.正确的输入...

取消回复欢迎 发表评论: