nginx 容器仅使用 4 个核心中的一个

nginx 容器仅使用 4 个核心中的一个

创建了一个具有 4 个静态 CPU 的 Nginx 容器

docker run -tid --cpus 4 --cpuset-cpus 6,7,8,9 --net=host --name mynginx nginx

docker exec -ti mynginx cat /etc/nginx/nginx.conf|grep worker_processes

worker_processes  auto;

已分配 CPU

taskset -acp 1426038
pid 1426038's current affinity list: 6-9

发送流量:

ab -n 10000000 -c 1000 http://172.16.91.5:80/

在顶部我可以看到核心 6 被使用,而所有剩余的核心都处于空闲状态。

来自 top-Nginx 核心

 %Cpu6  : 14.6 us, 57.3 sy,  0.0 ni, 28.2 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 %Cpu7  :  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 %Cpu8  :  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 %Cpu9  :  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st

操作系统核心

 %Cpu0  :  0.0 us,  2.8 sy,  0.0 ni, 32.1 id,  0.0 wa,  0.0 hi, 65.1 si,  0.0 st
 %Cpu1  :  0.0 us,  5.6 sy,  0.0 ni, 40.7 id,  0.0 wa,  0.0 hi, 53.7 si,  0.0 st
 %Cpu2  :  0.0 us,  0.9 sy,  0.0 ni, 29.9 id,  0.0 wa,  0.0 hi, 69.2 si,  0.0 st

平均负载:

    34.84, 19.62, 8.36

对这种行为有什么解释吗?

答案1

我猜 nginx 使用客户端 IP 的哈希值从池中选择一个工作进程。由于ab所有连接都来自同一个 IP 地址,它们最终都由单个工作进程处理,因此只加载一个 CPU 核心。

相关内容