搜索
查看: 293|回复: 0

生信分析云平台产品开发 - 8 软件稳定性测试

[复制链接]

9

主题

11

帖子

251

积分

中级会员

Rank: 3Rank: 3

积分
251
发表于 2019-10-29 14:26:41 | 显示全部楼层 |阅读模式
本帖最后由 豆浆包子 于 2019-12-2 14:18 编辑


前文链接:

前面文章讲述了更多的来自用户的需求分析,如何用技术方案解决用户需求、以及最终实现的效果,解决的是软件功能与特性的问题。
软件开发接近完成的时候,包括作者在内,都会有一个疑问:软件的稳定性如何?能否经受住高负载的考验?我的业务跑在上面,出问题怎么办?本文将使用稳定性测试的方法,解决以上疑问。

如何测试软件的稳定性?
简单的说,就是用测试软件录制人的操作行为得到录制的脚本,然后长时间用大量线程模拟人的操作。监控软件运行状态,并得到统计结果。
为什么这里跳过了单元测试、功能测试?
虽然开发过程中必然经过了单元测试、功能测试,但对于生信从业人员、企业用户来讲,这些概念过于专业,这里就不做过多描述了。

测试方案如下
测试环境:
服务器端(软件部署端)
CPU:I7 6700K  4 Core 8 Threads,4.8GHz
内存:64G 3200Mhz
硬盘:Intel 760P 512G
客户端(模拟访问端)
CPU: I7 8550U
内存:16G
硬盘:三星EVO 960 250G × 2
客户端运行:测试软件 Apache JMeter 5.1.1     JConsole,连接java虚拟机,查看测试时候java虚拟机运行情况
网络环境:服务器端和客户端通过千兆有线网络连接

测试过程:
Web软件开发领域常用的压力测试工具有:Load Runner和Apache Meter,这里使用的是Apache JMeter。
  • 配置好Apache JMeter Recorder入下图:

点击Start,运行Recorder服务,这里运行起来一个代理服务器,在客户端(模拟访问端)浏览器中代理服务器设置好JMeter的代理服务器地址。这样,客户端所有的文档行为,就会被JMeter录制下来,所得到的各种URL地址添加到线程组里。
  • 在客户端(模拟访问端)使用配置好的代理服务器,访问软件,登录系统,把所有功能依次使用一遍。得到了一组录制好的脚本,如下图:
  • 下一步就是模拟运行了,在Process里设置Number of Threads (users) : 10
    相当于模拟10个并发用户,理论上几百个用户都没有问题,这里设置为10(多次测试后:10个并发用户是因为受测试条件限制,启动测试后客户端测试机CPU满载,千兆网络满载;服务端负载CPU 20%左右,还有很大的余量,见后图)。而且本软件性质不属于高并发类型的系统,日常使用和可以预见的场景不会有太多的并发用户,追求的反而是长时间的稳定性。

​       点击工具栏上面绿色箭头启动测试,就会看到客户端发送大量的请求,测试就开始了。这时候打开服务端的任务管理器,就能够看到,CPU负载,网络流量升高。
  • 经过很多次测试,最长的一次持续一天时间。可以JConsole中看到,系统平稳运行。并在压力/稳定性测试结束后,系统仍在平稳运行。

  • 稳定性测试的结果:

可以简单的描述,用户录制的脚本平均执行了237678次(换算成日常操作次数,可能相当于几年的访问量),平均响应时间最长118ms(毫秒),异常0%。

经过这么严苛条件的稳定性测试之后,虽然也可能有个别测试盲区,但是这些数据从整体上已经足够判断一个软件的稳定性了。

官方网站:www.sliverworkspace.com 欢迎下载[PPT])或加QQ群:853718264讨论





上一篇:biopython的clustalwcommandline和MuscleCommandline
下一篇:ggstatsplot绘图|统计+可视化,学术科研神器
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|生信技能树 ( 粤ICP备15016384号  

GMT+8, 2019-12-6 07:16 , Processed in 0.024586 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.