Nginx处理请求体那点事

接收包体的两种方式

  • 接收完全部包体再发送
  •  一边接收包体一边发送

proxy_request_buffering  # 如果开启了 nginx会在内存开辟一块空间来缓存客户发来的请求

  语法:proxy_request_buffering on | off

  默认值:proxy_request_buffering on

on表示nginx接收完完整的body后才和upstream建立连接,off则是先建立连接,然后发送请求的时,从下游读取body,同时往上游转发。默认情况下是on,即nginx先生成要发往上游的包体,然后才去和上游建立连接。这样做是为了不耽误时间,不占用较长时间连接。因为一边读一边转发的问题是,一般下游和nginx之间的网速较慢,而nginx和upstream的网速较快(内网),这样边读边发会浪费很多时间。

 client_max_body_size  # 客户端请求体最大的大小

   语法:client_max_body_size szie

   默认值:client_max_body_size 1M

client_body_buffer_size  # 这个对应上面的proxy_request_buffering是否开启,如果开启了这个就是限制缓冲区大小的的相关指令

  语法:client_body_buffer_size size

  默认值:client_body_buffer_size 8k | 16k

请求体(Conten-Length)、client_max_body_size、client_body_buffer_size三者产生的一些情况探讨

  • Conten-length > client_max_body_size   

         ---->请求失败 ----->返回413: Request Entity Too Large

  • Conten-length < client_body_buffer_size 

         ----->请求体存储到内存中------>请求成功

  • client_body_buffer_size < Conten-length < clietn_max_body_size

        ----->请求体存储到磁盘client_body_temp_path path指定目录----->请求成功

client_body_in_single_buffer # 用来连接存储在内存中,不用随机查找,提高效率

     语法:client_body_in_single_buffer on | off

     默认值:client_body_in_single_buffer off

client_body_temp_path  # 如果请求体大小大于上面所设置的client_body_buffer_size 就存放在磁盘上的此目录下

     语法:client_body_temp_path path [ level1 ] [ level2 ] [ level3 ]

     默认值:client_body_temp_path client_body_temp

client_body_in_file_only #如果开启不管请求体的大小为多少都会存到磁盘上,on和clean有区别的,clean:当请求体被处理完成后会清除掉存在磁盘上的请求体内容,on:不会清除

  语法:client_body_in_file_only on | clean | off

  默认值:client_body_in_file_only off

client_body_timeout time #当客户端和nginx服务建立了连接后,设置一个不发请求体的一个超时时间

  语法:client_body_timeout time

  默认值:client_body_timeout 60s

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱琴孩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值