nginx 反向代理之 proxy_buffering

proxy_buffering主要是实现被代理服务器的数据和客户端的请求异步。

为了方便理解,我们定义三个角色,A为客户端,B为代理服务器,C为被代理服务器。

当proxy_buffering开启,A发起请求到B,B再到C,C反馈的数据先到B的buffer上,然后B会根据proxy_busy_buffer_size来决定什么时候开始把数据传输给A。

在此过程中,如果所有的buffer被写满,数据将会写入到temp_file中。

相反,如果proxy_buffering关闭,C反馈的数据实时地通过B传输给A。

以下配置,都是针对每一个http请求的:

1. proxy_buffering  on;
该参数设置是否开启proxy的buffer功能,参数的值为on或者off。
如果这个设置为off,那么proxy_buffers和proxy_busy_buffers_size这两个指令将会失效。 
但是无论proxy_buffering是否开启,proxy_buffer_size都是生效的

2. proxy_buffer_size  4k;
该参数用来设置一个特殊的buffer大小的。
从被代理服务器(C)上获取到的第一部分响应数据内容到代理服务器(B)上,通常是header,就存到了这个buffer中。 
如果该参数设置太小,会出现502错误码,这是因为这部分buffer不够存储header信息。建议设置为4k。

3. proxy_buffers  8  4k;
这个参数设置存储被代理服务器上的数据所占用的buffer的个数和每个buffer的大小。
所有buffer的大小为这两个数字的乘积。

4. proxy_busy_buffer_size 16k;
在所有的buffer里,我们需要规定一部分buffer把自己存的数据传给A,这部分buffer就叫做busy_buffer。
proxy_busy_buffer_size参数用来设置处于busy状态的buffer有多大。

对于B上buffer里的数据何时传输给A,我个人的理解是这样的:
1)如果完整数据大小小于busy_buffer大小,当数据传输完成后,马上传给A;
2)如果完整数据大小不少于busy_buffer大小,则装满busy_buffer后,马上传给A;

5. proxy_temp_path
语法:proxy_temp_path  path [level1 level2 level3]
定义proxy的临时文件存在目录以及目录的层级。

例:proxy_temp_path /usr/local/nginx/proxy_temp 1 2;
其中/usr/local/nginx/proxy_temp为临时文件所在目录,1表示层级1的目录名为1个数字(0-9),2表示层级2目录名为2个数字(00-99)

6. proxy_max_temp_file_size
设置临时文件的总大小,例如 proxy_max_temp_file_size 100M;

7. proxy_temp_file_wirte_size
设置同时写入临时文件的数据量的总大小。通常设置为8k或者16k。

配置示例:

server
{
    listen 80;
    server_name www.aminglinux.com;
    proxy_buffering on;
    proxy_buffer_size 4k;
    proxy_buffers 2 4k;
    proxy_busy_buffers_size 4k;
    proxy_temp_path /tmp/nginx_proxy_tmp 1 2;
    proxy_max_temp_file_size 20M;
    proxy_temp_file_write_size 8k;
    
    location /
    {
        proxy_pass      http://192.168.10.110:8080/;
        proxy_set_header Host   $host;
        proxy_set_header X-Real-IP      $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

### Nginx `proxy_buffering` 配置与作用详解 #### 1. `proxy_buffering` 的作用 `proxy_buffering` 是 Nginx 中用于控制代理缓冲行为的一个指令。当该参数被启用时(默认为开启状态),Nginx 将会缓存来自上游服务器(upstream)的响应数据到指定的缓冲区中,然后再将这些数据逐步发送给客户端[^1]。 这种机制的主要目的是优化性能并减少延迟。通过预先读取完整的响应内容或将部分内容加载至内存后再传输,可以有效降低频繁的小规模 I/O 操作带来的开销。即使后端服务处理速度较慢或者网络状况不佳,只要缓冲完成即可快速向用户交付资源。 然而需要注意的是,在某些场景下关闭此功能可能更合适,比如实时流媒体播放或聊天应用等需要即时交互的应用程序。因为如果启用了缓冲,则可能会导致前端接收到的数据存在滞后现象。 #### 2. 默认值及其上下文范围 - **默认值**: `on` - **适用范围**: 可应用于全局 (`http`)、虚拟主机(`server`) 或者特定位置路径(`location`) 下定义规则 例如下面这段配置表示对于根目录下的所有请求都采用无缓冲的方式传递给下游节点: ```nginx location / { proxy_pass http://backend; proxy_buffering off; } ``` 上述例子展示了如何禁用某个具体 URI 路径上的代理缓冲特性。 #### 3. 关于 `proxy_buffer_size` 无论 `proxy_buffering` 设置为何种状态(true/false),`proxy_buffer_size`(主缓冲器大小)始终处于工作当中。它主要用于保存从上层源接收过来HTTP头部信息部分的内容长度限制设定值。因此合理调整这个参数可以帮助改善大文件下载过程中可能出现的一些异常情况,如断连等问题[^3]。 #### 4. 结合实际案例分析 假设我们正在构建一套基于 LVS 和 Nginx 构建高可用负载均衡架构体系结构中的反向代理组件部署方案。此时考虑到不同业务需求差异较大,我们可以灵活运用以上提到的相关选项来满足各自特点的要求: - 对静态页面类别的访问可保持默认开启状态以提高吞吐量; - 而针对动态生成型API接口调用则建议适当调节甚至完全关闭该项开关以便获取更加及时准确的结果反馈[^4]。 --- ### 示例代码片段展示 这里给出一段简单的完整实例供参考学习之用: ```nginx http { include mime.types; default_type application/octet-stream; sendfile on; # 定义缓存空间的位置以及层次结构 proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=1g inactive=60m use_temp_path=off; server { listen 80; server_name localhost; location /static/ { root html; index index.html index.htm; # 开启缓冲加速静态资源分发效率 proxy_buffering on; proxy_buffers 8 4k; proxy_buffer_size 2k; } location /api/ { proxy_pass http://localhost:5000/; # 动态接口无需过多等待故而关闭缓冲策略 proxy_buffering off; } } } ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值