cgroups全称control groups,在RHEL6的2.6.32内核中已经包括了cgroup的patch。这里强烈建议安装RHEL6(CentOS6)来使用cgroups,如果没有的话,
只能升级内核了 ( > 2.6.26版本)
安装cgroups
apt-get install cgroup-bin
改变配置:vi /etc/cgconfig.conf
将最后的mount 改为如下形式:
mount { cpuset = /sys/fs/cgroup/cpuset; net_cls = /sys/fs/cgroup/net_cls; blkio = /sys/fs/cgroup/blkio; perf_event = /sys/fs/cgroup/perf_event; cpu = /sys/fs//cgroup/cpu; cpuacct = /sys/fs/cgroup/cpuacct; devices = /sys/fs/cgroup/devices; memory = /sys/fs/cgroup/memory; freezer = /sys/fs/cgroup/freezer; } |
cpu.shares:假设cgroup A的 tasks 的 cpu.shares 值为1,cgroup B的tasks的cpu.shares值为2,则cgroup B的进程占用的cpu时间是cgroup A上进程的2倍。
cpu.rt_runtime_us
cpu.rt_period_us: 这两个值建议不要设,让OS去调度占用的CPU时间的绝对值。
进入 cpu 目录:
sina@ubuntu:~$ cd /sys/fs/cgroup/cpu
创建目录:
# mkdir tinker
# mkdir tailor
下面通过taskset -c 3 ,启动两个虚拟机 并指定其 cpu affinity为cpu 3,启动2个虚拟机:
# taskset -c 3 ./for-test.sh
并在每个虚拟机中 满负荷运行 计算密集型程序。
观察两台虚拟机的PID,及cpu使用率:
root@ubuntu:~# ps -C qemu-system-i386 -opid,%cpu,psr,args PID %CPU PSR COMMAND 3237 50.1 3 /home/sina/Downloads/qemu-kvm-1.1.0/i386-softmmu/qemu-system-i386 3306 49.8 3 /home/sina/Downloads/qemu-kvm-1.1.0/i386-softmmu/qemu-system-i386 |
此时把两个qemu 任务的 pid分别 echo 进 tasks 文件中。并且修改 cpu/tinker 的 cpu.shares 为2048, cpu/tailor 的 cpu.shares 为512:
root@ubuntu:~# echo 3237 > /sys/fs/cgroup/cpu/tinker/tasks root@ubuntu:~# echo 3306 > /sys/fs/cgroup/cpu/tailor/tasks root@ubuntu:~# echo 2048 > /sys/fs/cgroup/cpu/tinker/cpu.shares root@ubuntu:~# echo 512 > /sys/fs/cgroup/cpu/tailor/cpu.shares |
此时观察两个任务的 cpu 使用率:
root@ubuntu:~# ps -C qemu-system-i386 -opid,%cpu,psr,args PID %CPU PSR COMMAND 3237 80 3 /home/sina/Downloads/qemu-kvm-1.1.0/i386-softmmu/qemu-system-i386 3306 20 3 /home/sina/Downloads/qemu-kvm-1.1.0/i386-softmmu/qemu-system-i386 |
设置了cpu.shares之后CPU利用率不会立刻就变为shares指定的那样,需要等待一段时间,基本上是个曲线的变化过程,之后就按照设置的数值来分配cpu使用率。
(须待以后在测试!!)