目录
一、cgroups简介
cgroups,是一个非常强大的linux内核工具,他不仅可以限制被namespace 隔离起来的资源,还可以 为资源设置权重、计算使用量、操控进程启停等等。所以cgroups (Control groups) 实现了对资源的配额和度量。
cgroups有四大功能:
- 资源限制:可以对任务使用的资源总额进行限制。
- 优先级分配:通过分配的cpu时间片数量以及磁盘IO带宽大小,实际上相当于控制了任务运行优先级。
- 资源统计:可以统计系统的资源使用量,如cpu时长,内存用量等。
- 任务控制: cgroup可以对任务 执行挂起、恢复等操作。
1.1 设置cpu使用率上限
Linux通过CFS(completely fair scheduler,完全公平调度器)来调度各个进程对cpu的使用
- 我们可以设置每个容器进程的调度周期,以及在这个周期内各个容器最多能使用多少cpu时间
- 使用–cpu-period即可设置调度周期,默认100ms,设置范围为:1ms-1s,对应的–cpu-period的数值范围是1000~10000000
- 使用–cpu-quota即可设置在每个周期内容器能使用cpu时间,默认无限制,设置的要求不能小于1ms,也就是–cpu-quota的值必须>=1000
查看周期限制和cpu配额限制
docker run -itd --name test centos:7 /bin/bash
#启动一个centos:7镜像容器
docker ps -a
#查看是否启动成功,并查看pid号
cd /sys/fs/cgroup/cpu/docker/容器PID号
#进入到该容器的限制目录中
cat cpu.cfs_quota_us
#查看每个周期的cpu最大限制时间
cat cpu.cfs_period_us
#查看调度周期是多久
//cpu.cfg_period_us: cpu 分配的周期(微秒,所以文件名中用us表示),默认为100000
//cpu.cfg_quota_us: 表示该cgroups限制占用的时间(微秒),默认为-1,表示为不限制,如果设为50000,表示占用50000/100000=50%的cpu
进行cpu压力测试然后修改每个周期的使用cpu的时间,查看cpu使用率
docker run -itd --name test1 --cpu-quota 50000 centos:7 /bin/bash
#可以直接创建一个容器并设置每个周期cpu执行的时间
或者
docker run -itd --name test1 centos:7 /bin/bash
cd /sys/fs/cgroup/cpu/docker/【容器pid】
echo 50000 > cpu.cfs_quota_us
#也可以先创建一个容器,然后进入到文件中直接修改cpu执行的实际的文件名称
docker exec -it 【容器id】 /bin/bash
#进入容器
vim /cpu.sh
#!bin/bash
i=0
while true
do
let i++
done
#创建死循环脚本,为了进行cpu压力测试
chmod +x /cpu.sh
./cpu.sh
#执行脚本
top
#查看这个容器中脚本占的多少的cpu资源