一 接收用户请求包体
- 说明: 虽然是被'http core核心'框架'处理',但是被'proxy'反向代理模块'使用'
-
- 重点: 哪些'指令'控制接收'request body'的行为?
- 控制: nginx接收'客户端 request body'的方式,'proxy模块提供的'
-
- 具体: on -->'收完body'再转发,使用'文件缓冲'
-
- off -->是'边接收'边转发,使用'内存缓冲' -->'关闭'包体缓存
- 1) on表示nginx'先'接收完'客户端完整的请求体body',后才和upstream'建立连接' -->"默认(内网网速大)"
-
- 2) off则是nginx'先与上游'建立连接,然后nginx'发送请求'的时,从'下游读取'请求body,同时往'上游'转发
-
- 场景: 有些'POST'请求上传文件,'请求体太大',而'下游和nginx之间'的网速'(一般是公网)'较慢
- 说明: 是'core'框架提供的
-
- 回顾: '请求的header'是在11个阶段'开始之前'接收,而body是在'content 阶段'接收
-
- 建议: 预设512k或者'1m'
- 1) 如果请求的body'小于'client_body_buffer_size,则分配'所需'的内存大小来接收
-
- 2) 如果请求的body'大于'client_body_buffer_size,那么在'接受第一段'client_body_buffer_size大小的数据后
-
- [1]、proxy_request_buffering on -->决定'先接收到完整'的body,内存不够只能保存进'临时'文件中
-
- 思考:在哪个'临时'文件中呢?--> 'client_body_temp 指定的路径中'
-
- [2]、proxy_request_buffering off -->决定'边接收'边'转发'给上游
② client_body_in_single_buffer
- 说明: 是'core模块'提供的,了解应用'场景' --> debug '定位'问题需要开启
-
- 含义: body是否必须'完整'存放到文件中,根据'参数'决定清除处理完是否删除文件的'body内容'
-
- 补充: client_body_in_file_only off含义;
-
- body'小于' 两个'内存页' 不会存'临时'文件
- 说明: 接收'body'后临时存放文件的'路径'格式
-
- 细节点: nginx'启动'以后会自动基于'--prefix'生成 默认'client_body_temp'的路径
细节点: 基于'请求头'中的'Content-Length'进行判断的
- 说明: 这里408是读取'请求体'超时
-
- 一般: 设置'65'即可
-
- 思考: 哪些因素会'影响'读取请求体超时? 网络时延?