首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >nginx容器只使用4个核心中的一个

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

Server Fault用户
提问于 2022-08-23 15:18:52
回答 1查看 288关注 0票数 1

使用4个静态CPU创建了一个Nginx容器

代码语言:javascript
复制
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

代码语言:javascript
复制
taskset -acp 1426038
pid 1426038's current affinity list: 6-9

发送流量:

代码语言:javascript
复制
ab -n 10000000 -c 1000 http://172.16.91.5:80/

在上面,我可以看到核心6被使用,因为所有剩余的核心都是空闲的。

来自顶Nginx核的

代码语言:javascript
复制
 %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

OS核

代码语言:javascript
复制
 %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

负载平均值:

代码语言:javascript
复制
    34.84, 19.62, 8.36

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

EN

回答 1

Server Fault用户

发布于 2022-08-23 16:06:15

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

票数 2
EN
页面原文内容由Server Fault提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://serverfault.com/questions/1108891

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档