nginx(六十二)proxy模块(三)接收用户请求的包体

一  接收用户请求包体

nginx读取请求体的源码分析

说明: 虽然是被'http core核心'框架'处理',但是被'proxy'反向代理模块'使用'
 
重点: 哪些'指令'控制接收'request body'的行为?

 ①  proxy_request_buffering

控制: nginx接收'客户端 request body'的方式,'proxy模块提供的'

具体: on  -->'收完body'再转发,使用'文件缓冲'
 
      off -->是'边接收'边转发,使用'内存缓冲' -->'关闭'包体缓存

1) on表示nginx'先'接收完'客户端完整的请求体body',后才和upstream'建立连接' -->"默认(内网网速大)"
 
2) off则是nginx'先与上游'建立连接,然后nginx'发送请求'的时,从'下游读取'请求body,同时往'上游'转发

场景: 有些'POST'请求上传文件,'请求体太大',而'下游和nginx之间'的网速'(一般是公网)'较慢

 ②  client_body_buffer_size 

说明: 是'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

$request_body为空或不准 

request_body日志频频为空

③  client_body_in_file_only

说明: 是'core模块'提供的,了解应用'场景' --> debug '定位'问题需要开启

含义: body是否必须'完整'存放到文件中,根据'参数'决定清除处理完是否删除文件的'body内容'

补充: client_body_in_file_only off含义; 

      body'小于'​ 两个'内存页' ​不会存'临时'文件

④  client_body_temp_path

说明: 接收'body'后临时存放文件的'路径'格式

细节点: nginx'启动'以后会自动基于'--prefix'生成 默认'client_body_temp'的路径

⑤  client_max_body_size 

细节点: 基于'请求头'中的'Content-Length'进行判断的

⑥  client_body_timeout 

说明: 这里408是读取'请求体'超时
 
一般: 设置'65'即可
 
思考: 哪些因素会'影响'读取请求体超时? 网络时延?

nginx 408报错的案例

socket缓冲区

tcpdump查看Nginx长连接还是短连接

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值