zoukankan      html  css  js  c++  java
  • Nginx核心要领五:worker_processes、worker_connections设置

    Nginx核心要领五:worker_processes、worker_connections设置
    原创闪耀的瞬间 最后发布于2019-05-31 13:15:53 阅读数 7571 收藏
    展开
    worker_processes与worker_connections 设置好合适大小,可以提示nginx处理性能,非常重要。

    原作者的话:
    As a general rule you need the only worker with large number of worker_connections, say 10,000 or 20,000.
    However, if nginx does CPU-intensive work as SSL or gzipping and you have 2 or more CPU, then you may
    set worker_processes to be equal to CPU number.
    Besides, if you serve many static files and the total size of the files is bigger than memory, then you may
    increase worker_processes to utilize a full disk bandwidth.
    Igor Sysoev

    翻译:
    一般一个进程足够了,你可以把连接数设得很大。(worker_processes: 1,worker_connections: 10,000)
    如果有SSL、gzip这些比较消耗CPU的工作,而且是多核CPU的话,可以设为和CPU的数量一样。(worker_processes: CPU核心数)
    或者要处理很多很多的小文件,而且文件总大小比内存大很多的时候,也可以把进程数增加,以充分利用IO带宽(主要似乎是IO操作有block)
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    worker_processes,工作进程数
    1.默认:worker_processes: 1
    2.调大:worker_processes: CPU核心数,(双核4线程,可以设置为4)
    worker_connections,单个工作进程可以允许同时建立外部连接的数量
    数字越大,能同时处理的连接越多

    1.默认:worker_connections: 1024
    2.调大:worker_connections: 100000,(调大到10万连接)
    worker_connections解析
    1.connections不是随便设置的,而是与两个指标有重要关联,一是内存,二是操作系统级别的“进程最大可打开文件数”。
    2.内存:每个连接数分别对应一个read_event、一个write_event事件,一个连接数大概占用232字节,2个事件总占用96字节,那么一个连接总共占用328字节,通过数学公式可以算出100000个连接数大概会占用 31M = 100000 * 328 / 1024 / 1024,当然这只是nginx启动时,connections连接数所占用的nginx。
    3.进程最大可打开文件数:进程最大可打开文件数受限于操作系统,可通过 ulimit -n 命令查询,以前是1024,现在是65535,
    nginx提供了worker_rlimit_nofile指令,这是除了ulimit的一种设置可用的描述符的方式。 该指令与使用ulimit对用户的设置是同样的效果。此指令的值将覆盖ulimit的值,如:worker_rlimit_nofile 20960;
    设置ulimits:ulimit -SHn 65535
    worker_processes 2;
    worker_rlimit_nofile 65535;
    #pid logs/nginx.pid;
    events {
    worker_connections 65535;
    }
    1
    2
    3
    4
    5
    6
    通过 ps -elf | grep nginx 找到 nginx 的worker进程ID
    通过 cat /proc/31613/limits 查看,其中2291是worker进程ID,请注意其中的Max open files


    从上面的分析可以看出nginx占用内存小,处理性能高,通过提高服务器的配置,Nginx可以应对更大的连接数
    ————————————————
    版权声明:本文为CSDN博主「闪耀的瞬间」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/zhuyu19911016520/java/article/details/90714429

  • 相关阅读:
    javascript 详解数组
    javascript ES5 Object对象
    JavaScript的检测属性、属性特性、枚举属性
    javascript之值传递与引用传递
    数据分析--数据可视化
    Mysql基础知识
    Excel-数据透视表
    如何做一份好的分析报告?
    面对问题,如何去分析?(流失问题)
    面对问题,如何去分析?(日报问题)
  • 原文地址:https://www.cnblogs.com/agang-php/p/12711060.html
Copyright © 2011-2022 走看看