nginx proxy之buffering和cache

proxy_buffer

proxy buffering的作用主要是实现被代理服务器和客户端的请求异步。比如说客户端A,代理服务器B,被代理服务器C,当A请求数据之后,C反馈的数据先到B的buffer上,然后B再根据buffer的设置来决定什么时候再把数据传给A。简单来说设置buffering就像快递员可以累计一定数量再送快递,不用来一个发一个。这种设置再并发量非常大的时候,可以节省cpu等服务器资源。
具体参数设置
proxy_buffering on;开启proxy的buffer功能

proxy_buffer_size;这个参数无论buffer是否开启都会生效。这是一个特殊buffer,当C返回的第一部分响应数据内容到b上,就是存到这个buffer上,如果这个参数设置太小,会出现502错误码,建议设置为4k。

proxy_buffers 8 4k;:这个是真正主要存储作用的buffer,表示8个4k大小的buffer,所有buffer的大小为两个数字的乘积。

proxy_busy_buffer_size 16k;在所有buffer里,我们需要规定先传一部分buffer数据先传给a,这部分就是busy_buffer。

proxy_temp_path;作用定义proxy的临时文件存在目录以及目录的层级。例如:
proxy_temp_path /usr/local/nginx/proxy_temp 1 2; 存放的位置proxy_temp,有两级目录,1表示层级目录为1(0-9),2表示层级目录为2(00-99),所有总共可以有10*100=1000个目录

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

proxy_temp_file_write_size;表示同时写入临时文件的数据量总大小。通常设置为8k或者16k。
示例配置:

    proxy_buffering on;
    proxy_buffer_size 4k;
    proxy_buffers 2 4k;
    proxy_busy_buffers_size 4k;
    proxy_temp_path /tmp/nginx_proxy 1 2;
    proxy_max_temp_file_size 20M;
    proxy_temp_file_write_size 8k;

proxy_cache

proxy_cache作用是将从C上获取的数据根据预设的规则存放到B上留着备用,当下次A再次请求相同数据的时候可以不用再到C上取,当然有一个时间限定。
参数:
proxy_cache:默认off,开启的话不是on,而是写一个存放缓存的区域名称,例如:proxy_cache my_zone;

proxy_cache_bypass:设置什么请求不读取cache,一定要从C中获取,这是从安全考虑。比如果proxy_cache_bypass $cookie_nocache $arg_nocache$arg_comment

proxy_no_cache:设定什么情况不缓存,作用和上面的类似。

proxy_cache_key:保持默认就行,不设置。

proxy_cache_path:例如:proxy_cache_path /data/nginx_cache/ levels=1:2 keys_zone=my_zone:10m inactive=300s max_size=5g 依次是存放位置,层级目录,zone的名称和大小,失效时间,最大缓存数据

示例:

//在全局配置http部分中添加
proxy_cache_path /data/nginx_cache/ levels=1:2 keys_zone=my_zone:10m inactive=300s max_size=50M;

//在虚拟主机server的location中
proxy_cache my_zone;
### 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、付费专栏及课程。

余额充值