root@ubuntu:~# ps -C a.out -opid,%cpu,psr,args
  PID %CPU PSR COMMAND
  3944 33.6   3 ./a.out
  3945 66.4   3 ./a.out
  再启动一个测试程序:
  [html] view plaincopy
  sina@ubuntu:~$ ./a.out &
  [2] 5503
  可观察到cpu使用率是 :
  root@ubuntu:~# ps -C a.out -opid,%cpu,psr,args
  PID %CPU PSR COMMAND
  5503 99.6   1 ./a.out
  仅将进程 5503 放到 cpu子系统中,一段时间后观察cpu使用率:
  root@ubuntu:/sys/fs/cgroup/cpu/tailor# echo 5503 > tasks
  可看到几乎没什么变化:(因为这个时候还没有设置 进程的cpu affinity 属性)
  root@ubuntu:~# ps -C a.out -opid,%cpu,psr,args
  PID %CPU PSR COMMAND
  3944 33.6   3 ./a.out
  3945 66.4   3 ./a.out
  5503 99.6   1 ./a.out
  再将进程 5503 放到 cpuset 子系统中,一段时间后观察cpu使用率:
  root@ubuntu:/sys/fs/cgroup/cpuset/tailor# echo 5503 > tasks
  root@ubuntu:~# ps -C a.out -opid,%cpu,psr,args
  PID %CPU PSR COMMAND
  3944 33.4   3 ./a.out
  3945 33.3   3 ./a.out
  5503 33.3  3 ./a.out
  结论:从上面的测试结果可以看出,各个 cgroup 之间基本上能够按照 cpu.shares 设定的比例共享CPU资源,对于同一个cgroup中的一组进程则被公平的调度。
  测试运用 cpu.rt_period_us 和 cpu.rt_runtime_us 来控制CPU资源的分配
  [html] view plaincopy
  root@ubuntu:/sys/fs/cgroup/cpu/tailor# echo 200000 > cpu.rt_runtime_us
  一段时间之后观察 3 进程的cpu使用率:
  root@ubuntu:~# ps -C a.out -opid,%cpu,psr,args
  PID %CPU PSR COMMAND
  3944 33.4   3 ./a.out
  3945 10.0   3 ./a.out
  5503 9.9   3 ./a.out
  通过上面结果可以看出   设置  cpu.rt_runtime_us   和  cpu.rt_period_us  可以 设置CPU的利用率上限,不会让某个进程或虚拟机占用过多的CPU资源。