深入浅出 -- 系统架构之负载均衡Nginx缓冲区

一、Nginx缓冲区

   先来思考一个问题,接入Nginx的项目一般请求流程为:“客户端→Nginx→服务端”,在这个过程中存在两个连接:“客户端→NginxNginx→服务端”,那么两个不同的连接速度不一致,就会影响用户的体验(比如浏览器的加载速度跟不上服务端的响应速度)。
其实也就类似电脑的内存跟不上CPU速度,所以对于用户造成的体验感极差,因此在CPU设计时都会加入三级高速缓冲区,用于缓解CPU和内存速率不一致的矛盾。在Nginx也同样存在缓冲区的机制,主要目的就在于:用来解决两个连接之间速度不匹配造成的问题,有了缓冲后,Nginx代理可暂存后端的响应,然后按需供给数据给客户端。先来看看一些关于缓冲区的配置项:

  • proxy_buffering:是否启用缓冲机制,默认为on关闭状态。
  • client_body_buffer_size:设置缓冲客户端请求数据的内存大小。
  • proxy_buffers:为每个请求/连接设置缓冲区的数量和大小,默认4 4k/8k
  • proxy_buffer_size:设置用于存储响应头的缓冲区大小。
  • proxy_busy_buffers_size:在后端数据没有完全接收完成时,Nginx可以将busy状态的缓冲返回给客户端,该参数用来设置busy状态的buffer具体有多大,默认为proxy_buffer_size*2
  • proxy_temp_path:当内存缓冲区存满时,可以将数据临时存放到磁盘,该参数是设置存储缓冲数据的目录。
    • 语法:proxy_temp_path path;
      • path是临时目录的路径。
  • proxy_temp_file_write_size:设置每次写数据到临时文件的大小限制。
  • proxy_max_temp_file_size:设置临时的缓冲目录中允许存储的最大容量。
  • 非缓冲参数项:
    • proxy_connect_timeout:设置与后端服务器建立连接时的超时时间。
    • proxy_read_timeout:设置从后端服务器读取响应数据的超时时间。
    • proxy_send_timeout:设置向后端服务器传输请求数据的超时时间。

具体的nginx.conf配置如下:

http{
    proxy_connect_timeout 10;
    proxy_read_timeout 120;
    proxy_send_timeout 10;
    proxy_buffering on;
    client_body_buffer_size 512k;
    proxy_buffers 4 64k;
    proxy_buffer_size 16k;
    proxy_busy_buffers_size 128k;
    proxy_temp_file_write_size 128k;
    proxy_temp_path /soft/nginx/temp_buffer;
}

上述的缓冲区参数,是基于每个请求分配的空间,而并不是所有请求的共享空间。当然,具体的参数值还需要根据业务去决定,要综合考虑机器的内存以及每个请求的平均数据大小。

最后提一嘴:使用缓冲也可以减少即时传输带来的带宽消耗。

相关推荐

  1. 深入浅出 -- 系统架构负载均衡Nginx缓冲区

    2024-04-08 22:26:03       14 阅读
  2. 深入浅出 -- 系统架构负载均衡Nginx跨域配置

    2024-04-08 22:26:03       13 阅读
  3. 深入浅出 -- 系统架构负载均衡Nginx配置SSL证书

    2024-04-08 22:26:03       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-08 22:26:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-08 22:26:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-08 22:26:03       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-08 22:26:03       20 阅读

热门阅读

  1. Shell学习 - 2.25 Shell $[]:对整数进行数学运算

    2024-04-08 22:26:03       13 阅读
  2. ChatGPT革新学术写作方式:打造出色论文

    2024-04-08 22:26:03       13 阅读
  3. qiankun按需加载微应用方案

    2024-04-08 22:26:03       13 阅读
  4. 【阅读笔记】《同意》

    2024-04-08 22:26:03       13 阅读
  5. 详细介绍下PYTHON API的用法

    2024-04-08 22:26:03       16 阅读
  6. [TS面试]TS中类型的全局声明与局部声明?

    2024-04-08 22:26:03       14 阅读
  7. 我的项目笔记

    2024-04-08 22:26:03       14 阅读
  8. C++学习笔记九--模版

    2024-04-08 22:26:03       13 阅读
  9. Linux——gcc

    2024-04-08 22:26:03       15 阅读
  10. 【LeetCode热题100】33. 搜索旋转排序数组(二分)

    2024-04-08 22:26:03       11 阅读
  11. Flutter 单例模式的多种实现方法与使用场景分析

    2024-04-08 22:26:03       13 阅读