使用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;taskset -acp 1426038
pid 1426038's current affinity list: 6-9ab -n 10000000 -c 1000 http://172.16.91.5:80/在上面,我可以看到核心6被使用,因为所有剩余的核心都是空闲的。
来自顶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对这种行为有什么解释吗?
发布于 2022-08-23 16:06:15
我的猜测是,nginx使用客户端IP的散列从池中选择一个工作人员。由于使用ab,所有连接都来自同一个IP地址,它们最终都由单个工作人员处理,因此只能加载一个CPU核心。
https://serverfault.com/questions/1108891
复制相似问题