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