一 接收上游的响应
- 前提: nginx与上游'建立'连接,把nginx生成的'请求(line、header、body)'信息发送给'上游'
-
- 补充: '上游'解析处理完之后,会发送'响应'
-
- 核心: nginx如何'接收'、'解析'、'处理'上游响应行、响应头、响应体
(1)接收上游的HTTP头部
- 建议值: 64k或'128k'
-
- 1)'接收(upstream模块处理的)'上游的'响应'头部,限制了上游'响应头'的大小
-
- 补充: '处理'响应头部是'各个proxy模块'来处理的
-
- 2) 常见:响应头中的'Set-Cookies'特别长,'超过'了这个限制
-
- error.log报错: upstream sent too big header while reading response header
-
- 思考: 如何获取'响应头'的大小 -->'$upstream_bytes_received'-'$upstream_response_length'
-
- 补充: 这个指令不受'proxy_buffering'指令开关的限制

(2)接收上游的HTTP包体
- 1) 明确'on'和'off'对应的行为
-
- 2) 通过上游服务器的'X-Accel-Buffering(nginx认识)'响应头来控制nginx读取'上游响应'的行为
-
- 3) off --> nginx'一次'能接收的是'proxy_buffer_size'的大小,然后'发送'给客户端

- 说明: 即使开启了'proxy_buffering on',也'不一定'会将'body'写入磁盘
-
- 补充: 如果'响应body'很小,'内存(8*4k)'就可以接收,没有必要放入'磁盘文件(吸盘I/O比较慢)'中

细节点: 如果上游'返回(下载场景)'一个'很大(>1G)'的文件,临时文件'不足以容纳'会报错
说明:nginx接收上游'body'后,'如果'需要放入'临时文件'中,每一次'向磁盘临时文件'写入的字节数
(3)及时转发包体
- 说明: 从' proxy_buffer_size'和'proxy_buffers'开辟一块缓冲区,发送响应给客户端
-
- 举例: 上游发送'1G'的文件,nginx一旦收到'8k'或者'16k','及时转发body'给客户端
-
- 前提: proxy_buffering是'开启'才生效
-
- 作用: 虽然'缓存'了'上游'的响应,但是想'更快'的给'客户端'发送'部分'响应

(4)接收上游时网络速度

- 两次read操作: 从'系统'socket缓冲区'调用两次read方法'读取内容的超时
-
- 大白话: 如果nginx'连续的 60s 内'没有收到后端服务器的' 1 个字节', nginx'主动'连接关闭
说明: 限制的是'读取上游返回响应'的速度

(5)上游包体的持久化
- 1) 上游包体的'持久化'
-
- 2) 在做'文件缓存服务器'场景下很合适
-
- 3) 相当于'偷偷'复制了一份'body'
-
- ++++++++++ 'proxy store 与proxy cache的区别' ++++++++++
-
- proxy store'不提供'缓存过期更新、内存索引建立等功能,缓存文件'一直会保存'在本地磁盘中
-


二 案例讲解指令

