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 子系统
  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 使用率:
  设置了cpu.shares之后CPU利用率不会立刻变为shares指定的那样,需要等待一段时间,基本上是个曲线的变化过程,之后按照设置的数值来分配cpu使用率。
  (须待以后在测试!!)