一 接收上游的响应
前提: nginx与上游'建立'连接,把nginx生成的'请求(line、header、body)'信息发送给'上游'
补充: '上游'解析处理完之后,会发送'响应'
核心: nginx如何'接收'、'解析'、'处理'上游响应行、响应头、响应体
下载大文件失败
(1)接收上游的HTTP头部
① proxy_buffer_size
建议值: 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包体
② proxy_buffering
1) 明确'on'和'off'对应的行为
2) 通过上游服务器的'X-Accel-Buffering(nginx认识)'响应头来控制nginx读取'上游响应'的行为
3) off --> nginx'一次'能接收的是'proxy_buffer_size'的大小,然后'发送'给客户端
③ proxy_buffers
说明: 即使开启了'proxy_buffering on',也'不一定'会将'body'写入磁盘
补充: 如果'响应body'很小,'内存(8*4k)'就可以接收,没有必要放入'磁盘文件(吸盘I/O比较慢)'中
④ proxy_max_temp_file_size
细节点: 如果上游'返回(下载场景)'一个'很大(>1G)'的文件,临时文件'不足以容纳'会报错
⑤ proxy_temp_file_write_size
说明:nginx接收上游'body'后,'如果'需要放入'临时文件'中,每一次'向磁盘临时文件'写入的字节数
⑥ proxy_temp_path
(3)及时转发包体
⑦ proxy_busy_buffers_size
说明: 从' proxy_buffer_size'和'proxy_buffers'开辟一块缓冲区,发送响应给客户端
举例: 上游发送'1G'的文件,nginx一旦收到'8k'或者'16k','及时转发body'给客户端
前提: proxy_buffering是'开启'才生效
作用: 虽然'缓存'了'上游'的响应,但是想'更快'的给'客户端'发送'部分'响应
(4)接收上游时网络速度
⑧ proxy_read_timeout
两次read操作: 从'系统'socket缓冲区'调用两次read方法'读取内容的超时
大白话: 如果nginx'连续的 60s 内'没有收到后端服务器的' 1 个字节', nginx'主动'连接关闭
⑨ proxy_limit_rate
说明: 限制的是'读取上游返回响应'的速度
(5)上游包体的持久化
⑩ proxy_store
1) 上游包体的'持久化'
2) 在做'文件缓存服务器'场景下很合适
3) 相当于'偷偷'复制了一份'body'
++++++++++ 'proxy store 与proxy cache的区别' ++++++++++
proxy store'不提供'缓存过期更新、内存索引建立等功能,缓存文件'一直会保存'在本地磁盘中
⑪ proxy_store_access
二 案例讲解指令
通过下载大文件失败了解各指令的含义