Docker下使用stress进行压力测试

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

1
2
3
4
5
6
7
[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 image  for  joedval /stress :latest

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
[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、继续生成一个容器

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
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、查看容器信息:

1
2
3
4
5
[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、测试内存:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[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,所以自动退出了)









本文转自 冰冻vs西瓜 51CTO博客,原文链接:http://blog.51cto.com/molewan/1757918,如需转载请自行联系原作者
优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/508598

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。