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,如需转载请自行联系原作者
目录
相关文章
|
关系型数据库 测试技术 数据库
使用Docker搭建测试用例管理平台TestLink:简易指南
使用Docker搭建TestLink测试管理软件的步骤如下:首先,拉取`bitnami/mariadb`和`bitnami/testlink-archived`镜像。然后,启动MariaDB容器,创建数据库。接着,启动TestLink容器并连接到MariaDB。检查容器状态确保它们已启动。最后,访问`localhost:8099`以使用TestLink,默认用户名为`user`,密码为`bitnami`。这样,你就能在本地便捷地进行测试管理了。
|
Ubuntu Cloud Native 测试技术
百度搜索:蓝易云【云原生之使用Docker部署ubuntu测试环境】
请注意,以上步骤仅是简单的使用Docker部署Ubuntu测试环境的示例。在实际应用中,您可能需要根据测试需求和应用场景进行更多的配置和优化。同时,在退出容器时,容器并未删除,您可以使用 `docker rm <容器名称>`命令来删除容器。在进行测试时,请谨慎操作,并确保对Docker的使用有一定的了解,以避免不必要的问题。
189 2
|
测试技术 Docker 容器
使用Docker构建多环境应用:开发、测试、生产环境
Docker已经成为了现代应用程序开发和部署的核心工具之一。通过使用Docker,开发团队可以轻松地在不同的环境中构建、测试和部署应用程序,从而提高开发速度和应用程序的可移植性。本文将介绍如何使用Docker构建多环境应用,包括开发、测试和生产环境,并提供丰富的示例代码,以帮助大家轻松应对不同环境的挑战。
|
jenkins 测试技术 持续交付
基于Jenkins+Python+Ubuntu+Docker的接口/UI自动化测试环境部署详细过程
基于Jenkins+Python+Ubuntu+Docker的接口/UI自动化测试环境部署详细过程
1319 1
|
存储 NoSQL 大数据
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
213 3
|
运维 测试技术 Linux
关于Stress 压力测试工具的介绍与使用
在日益复杂的计算环境中,保证系统的稳定性和性能成为了每个Linux管理员的核心任务。面对不断增长的数据量和业务需求,如何有效评估系统极限和潜在瓶颈? 压力测试工具:stress,成为了不可或缺的助手。这篇记录描述stress工具的使用方法及其在模拟真实负载中的实用性。
关于Stress 压力测试工具的介绍与使用
|
消息中间件 测试技术 RocketMQ
docker部署RockerMQ单机测试环境
docker部署RockerMQ单机测试环境
|
关系型数据库 MySQL 测试技术
使用docker部署MySQL测试环境
使用docker部署MySQL测试环境
339 0
|
IDE 前端开发 时序数据库
【Docker项目实战】使用Docker部署speedtest-tracker速度测试追踪器
【6月更文挑战第4天】使用Docker部署speedtest-tracker速度测试追踪器
1315 1
|
分布式计算 大数据 Hadoop
最快方式搭建docker大数据 测试集群
【8月更文挑战第5天】快速搭建Docker大数据测试集群可采用预构建镜像与Compose文件、利用云服务如AWS的ECS、自动化工具如Ansible或参考在线教程。只需简单配置如内存分配及路径,运行`docker-compose up`即可启动含NameNode、DataNode等组件的Hadoop集群。根据需求与资源选择合适方法。
247 0