1、下载一个stress压力工具的镜像

[root@docker ~]# docker pull joedval/stress
Pulling repository joedval/stress
7eb627cb08a2: Download complete 
b0082ba983ef: Download complete 
109b72e23ca5: Download complete 
a1a076997d57: Download complete 
Status: Downloaded newer p_w_picpath for joedval/stress:latest

2、随机生成一个以“joedval/stress”镜像为基础的容器,设定权级为512

[root@docker ~]# docker run -it --rm -c 512 joedval/stress --cpu 1
stress: info: [1] dispatching hogs: 1 cpu, 0 io, 0 vm, 0 hdd
可以看到cpu占用为99.6%,接近100%
[root@docker ~]# top
top - 15:19:07 up  1:04,  3 users,  load average: 1.62, 1.03, 0.43
Tasks: 158 total,   2 running, 156 sleeping,   0 stopped,   0 zombie
Cpu(s): 99.3%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.3%hi,  0.0%si,  0.0%st
Mem:   3910160k total,  1289624k used,  2620536k free,    96856k buffers
Swap:  4194300k total,        0k used,  4194300k free,   914440k cached
   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                              
  4144 root      20   0  7208  120   28 R 99.6  0.0   2:58.09 stress                                                                                
  4403 root      20   0 15032 1252  924 R  0.3  0.0   0:00.32 top                                                                                   
     1 root      20   0 19356 1532 1228 S  0.0  0.0   0:01.55 init                                                                                  
     2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd                                                                              
     3 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0                                                                           
     4 root      20   0     0    0    0 S  0.0  0.0   0:00.03 ksoftirqd/0                                                                           
     5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0                                                                             
     6 root      RT   0     0    0    0 S  0.0  0.0   0:00.02 watchdog/0                                                                            
     7 root      20   0     0    0    0 S  0.0  0.0   0:01.62 events/0                                                                              
     8 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events/0                                                                              
     9 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_long/0                                                                         
    10 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_power_ef                                                                       
    11 root      20   0     0    0    0 S  0.0  0.0   0:00.00 cgroup                                                                                
    12 root      20   0     0    0    0 S  0.0  0.0   0:00.00 khelper                                                                               
    13 root      20   0     0    0    0 S  0.0  0.0   0:00.03 netns                                                                                 
    14 root      20   0     0    0    0 S  0.0  0.0   0:00.00 async/mgr                                                                             
    15 root      20   0     0    0    0 S  0.0  0.0   0:00.00 pm                                                                                    
    16 root      20   0     0    0    0 S  0.0  0.0   0:00.02 sync_supers                                                                           
    17 root      20   0     0    0    0 S  0.0  0.0   0:00.01 bdi-default

3、继续生成一个容器

root@docker ~]# docker run -it --rm -c 512 joedval/stress --cpu 1
stress: info: [1] dispatching hogs: 1 cpu, 0 io, 0 vm, 0 hdd
[root@docker ~]# top
top - 15:20:48 up  1:05,  3 users,  load average: 1.55, 1.13, 0.52
Tasks: 164 total,   3 running, 161 sleeping,   0 stopped,   0 zombie
Cpu(s): 99.0%us,  0.7%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.3%hi,  0.0%si,  0.0%st
Mem:   3910160k total,  1298324k used,  2611836k free,    97924k buffers
Swap:  4194300k total,        0k used,  4194300k free,   917480k cached
   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                              
  4772 root      20   0  7208  124   28 R 49.9  0.0   0:16.12 stress                                                                                
  4144 root      20   0  7208  120   28 R 49.5  0.0   4:22.39 stress                                                                                
     1 root      20   0 19356 1532 1228 S  0.0  0.0   0:01.55 init                                                                                  
     2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd                                                                              
     3 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0                                                                           
     4 root      20   0     0    0    0 S  0.0  0.0   0:00.03 ksoftirqd/0                                                                           
     5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0                                                                             
     6 root      RT   0     0    0    0 S  0.0  0.0   0:00.02 watchdog/0                                                                            
     7 root      20   0     0    0    0 S  0.0  0.0   0:01.66 events/0                                                                              
     8 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events/0                                                                              
     9 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_long/0                                                                         
    10 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_power_ef                                                                       
    11 root      20   0     0    0    0 S  0.0  0.0   0:00.00 cgroup                                                                                
    12 root      20   0     0    0    0 S  0.0  0.0   0:00.00 khelper                                                                               
    13 root      20   0     0    0    0 S  0.0  0.0   0:00.03 netns                                                                                 
    14 root      20   0     0    0    0 S  0.0  0.0   0:00.00 async/mgr                                                                             
    15 root      20   0     0    0    0 S  0.0  0.0   0:00.00 pm                                                                                    
    16 root      20   0     0    0    0 S  0.0  0.0   0:00.02 sync_supers                                                                           
    17 root      20   0     0    0    0 S  0.0  0.0   0:00.01 bdi-default        
然后,可以发现存在两个stress的进程,各占用49.5%
我们再次添加一个容器,并修改下stress权限为1024
[root@docker ~]# top
top - 15:22:13 up  1:07,  4 users,  load average: 2.53, 1.50, 0.70
Tasks: 171 total,   4 running, 167 sleeping,   0 stopped,   0 zombie
Cpu(s): 99.3%us,  0.3%sy,  0.0%ni,  0.0%id,  0.0%wa,  0.3%hi,  0.0%si,  0.0%st
Mem:   3910160k total,  1318152k used,  2592008k free,    99008k buffers
Swap:  4194300k total,        0k used,  4194300k free,   921024k cached
   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                              
  4992 root      20   0  7208  120   28 R 49.5  0.0   0:09.79 stress                                                                                
  4144 root      20   0  7208  120   28 R 24.9  0.0   4:59.56 stress                                                                                
  4772 root      20   0  7208  124   28 R 24.6  0.0   0:53.28 stress                                                                                
     1 root      20   0 19356 1532 1228 S  0.0  0.0   0:01.55 init                                                                                  
     2 root      20   0     0    0    0 S  0.0  0.0   0:00.01 kthreadd                                                                              
     3 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0                                                                           
     4 root      20   0     0    0    0 S  0.0  0.0   0:00.03 ksoftirqd/0                                                                           
     5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0                                                                             
     6 root      RT   0     0    0    0 S  0.0  0.0   0:00.02 watchdog/0                                                                            
     7 root      20   0     0    0    0 S  0.0  0.0   0:01.69 events/0                                                                              
     8 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events/0                                                                              
     9 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_long/0                                                                         
    10 root      20   0     0    0    0 S  0.0  0.0   0:00.00 events_power_ef                                                                       
    11 root      20   0     0    0    0 S  0.0  0.0   0:00.00 cgroup                                                                                
    12 root      20   0     0    0    0 S  0.0  0.0   0:00.00 khelper                                                                               
    13 root      20   0     0    0    0 S  0.0  0.0   0:00.03 netns                                                                                 
    14 root      20   0     0    0    0 S  0.0  0.0   0:00.00 async/mgr                                                                             
    15 root      20   0     0    0    0 S  0.0  0.0   0:00.00 pm                                                                                    
    16 root      20   0     0    0    0 S  0.0  0.0   0:00.02 sync_supers

4、查看容器信息:

[root@docker ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES
fcc6cb7b064c        joedval/stress      "stress --cpu 1"    29 seconds ago      Up 28 seconds                                   drunk_rosalind      
7c195fe2e038        joedval/stress      "stress --cpu 1"    2 minutes ago       Up 2 minutes                                    loving_galileo      
9b19fbca489b        joedval/stress      "stress --cpu 1"    7 minutes ago       Up 7 minutes                                    furious_rosalind

5、测试内存:

[root@docker ~]# docker run -it --rm -m 128m joedval/stress --vm 1 --vm-bytes 120m --vm-hang 0
stress: info: [1] dispatching hogs: 0 cpu, 0 io, 1 vm, 0 hdd
[root@docker ~]# docker ps -l
CONTAINER ID        IMAGE               COMMAND                CREATED             STATUS              PORTS               NAMES
9841ee711d7f        joedval/stress      "stress --vm 1 --vm-   8 seconds ago       Up 6 seconds                            boring_jones       
[root@docker ~]# docker run -it --rm -m 128m joedval/stress --vm 1 --vm-bytes 512m --vm-hang 0
stress: info: [1] dispatching hogs: 0 cpu, 0 io, 1 vm, 0 hdd
stress: FAIL: [1] (415) <-- worker 5 got signal 9
stress: WARN: [1] (417) now reaping child worker processes
stress: FAIL: [1] (421) kill error: No such process
stress: FAIL: [1] (451) failed run completed in 3s
[root@docker ~]# docker run -it --rm -m 128m joedval/stress --vm 1 --vm-bytes 255m --vm-hang 0
stress: info: [1] dispatching hogs: 0 cpu, 0 io, 1 vm, 0 hdd
[root@docker ~]# docker run -it --rm -m 128m joedval/stress --vm 1 --vm-bytes 256m --vm-hang 0
stress: info: [1] dispatching hogs: 0 cpu, 0 io, 1 vm, 0 hdd
stress: FAIL: [1] (415) <-- worker 6 got signal 9
stress: WARN: [1] (417) now reaping child worker processes
stress: FAIL: [1] (421) kill error: No such process
stress: FAIL: [1] (451) failed run completed in 2s
说明:不能超过预设值的两倍(比如上面案例中256m是128m,所以自动退出了)