前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >针对 CPU 的Nginx 配置优化

针对 CPU 的Nginx 配置优化

作者头像
拓荒者
发布2019-03-15 18:58:45
8890
发布2019-03-15 18:58:45
举报
文章被收录于专栏:运维经验分享运维经验分享

处理器正处于多核时代。多内核是指在一枚处理器中集成两个或多个完整的计算引擎,多核处理器是单芯片。一枚多核处理器上可以承载多个内核,但只需要单一的处理器插槽即可以工作,同时,目前流行的操作系统已经可以利用这样的资源,将每个执行内核作为分离的逻辑处理器,通过在多个执行内核之间划分任务,在特定的始终周期内执行更多任务,提高并行处理任务的能力。

    在Nginx 配置文件中,有这样两个指令:worker_processes 和 worker_cpu_affinity 它们可以针对多核CPU 进行配置优化。

1.worker_processes 指令

指令详解:worker_processes 指令用来设置Nginx 服务的进程数。官方文档 建议此指令一般设置为1即可,赋值过多会影响系统IO效率,降低Nginx 服务器的性能。根据前辈们的经验,为了让多核CPU 能够很好的并行处理任务,我们可以将该指令的赋值适当的增大一些,最好赋值为机器CPU 的倍数,当然,这个值并不是越大越好,Nginx 进程太多可能增加主进程调度负担,也可能影响系统的IP 效率。比如我们的机器CPU 为4核 设置为

worker_processes 4;

    设置好worker_processes 指令后,就很有必要设置worker_cpu_affinity 指令。

2.worker_cpu_affinity 指令

指令详解:worker_cpu_affinity 指令用来为每个进程分配CPU的工作内核。这个指令的设置方法有些麻烦。我们先来看一张图  如图所示,worker_cpu_affinity 指令的值是由几组二进制表示的。其中每一组代表一个进程,每组中的每一位表示该进程使用CPU的情况,1代表使用,0 代表不适用,注意,二进制位排列顺序和CPU 的顺序是相反的,建议不同的进程平均分配到不同的CPU 运行内核上。

以上面设置 的进程数4 为例  CPU 是四核 因此就会有四组值,并且每组有四位,所以,此指令的设置为

worker_cpu_affinity 0001 0100 1000 0010;

四个二进制数分别对应4个进程,第一个进程对应0001,表示使用第一个CPU 内核,第二个进程对应0010,表示使用第二个CPU 内核,以此类推。

如果 我们将 worker_processes 指令的值复制为8, 即复制为CPU 内核个数的两倍 则woker_cpu_affinity 指令的设置可以是

worker_cpu_affinity  00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档