Nginx反向代理的配置语法

Nginx反向代理模块的指令是由ngx_http_proxy_module模块进行解析

proxy_pass

用来设置被代理服务器地址,可以是主机名称、IP地址加端口号形式

URL:需要进行设置的被代理服务器地址,包含传输协议(http,https://)、主机名称或IP地址加端口号、URI等要素

当proxy_pass时,要注意是否要在URL后面加 / 的问题:

当客户端访问 http://localhost/index.html,效果是一样的


当客户端访问 http://localhost/server/index.html 的时候

第一个proxy_pass就变成了 http://localhost/server/index.html

第二个proxy_pass就变成了 http://localhost/index.html 效果就不一样了

当没有斜杠时,location后的路径会加上去,有斜杠时,则不会。


proxy_set_header

更改Nginx服务器接收到的客户端请求的请求头信息,然后将新的请求头发送给代理的服务器

测试案例:以140为代理服务器,141为被代理服务器,发送请求头信息username为HZY

代理服务器 [192.168.174.140]

被代理服务器 [192.168.174.141]


proxy_redirect

重置头信息中的”Location”和”Refresh”的值

测试案例:

当发送192.168.174.140:8081/add.html请求时,代理服务端(140)将请求代理到 141

服务端(141)判断当前请求的资源路径是否为空,如果为空,则返回状态码302,临时重定向到192.168.174.141:80,访问默认的index.html


反向代理案例

如图所示,当用户发送请求到代理服务器端,http://192.168.174.140:8082/server1,请求将会被代理到http://192.168.174.141:9001/上面


反向代理系统调优

反向代理值:Buffer(缓冲)和Cache(缓存)

相同点:两种方式都是提高IO吞吐效率,提升nginx代理的性能

不同点:

Buffer是用来解决不同设备之间数据传递速度不一致导致的性能低的问题,BUffer中的数据一旦此次操作完成后,就可以删除

Cache主要是备份,将被代理服务器的数据缓存一份到代理服务器上去。当客户端再次获取相同的数据时,就只需要从代理服务器上去获取,而不需要再次通过被代理服务器,效率高,缓存中的数据可以重复使用,只有满足特定的条件才会删除

Proxy Buffer相关指令

1)proxy_buffering

该指令用来开启或者关闭代理服务器的缓冲区


2)proxy_buffers

指定单个连接从代理服务器读取响应的缓存区的个数和大小

number:缓存区的个数

size:每个缓存区的大小,缓存区的总大小为number*size


3)proxy_buffer_size

设置从被代理服务器获取的第一部分响应数据的大小。保持与proxy_buffers中的size一致即可,当然也可以更小。


4)proxy_busy_buffers_size

用来限制同时处于BUSY状态的缓冲总大小。


5)proxy_temp_path

当缓冲区存满后,仍未被Nginx服务器完全接受,响应数据就会被临时存放在磁盘文件上,该指令设置文件路径

注意path最多设置三层


6)proxy_temp_file_write_size

用来设置磁盘上缓冲文件的大小


通用网站的配置

1
2
3
4
proxy_buffering on;
proxy_buffer_size 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;