创建了一个具有 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 核心。