博客
关于我
【IT之路】性能测试系列 -- 初识性能测试
阅读量:321 次
发布时间:2019-03-03

本文共 2454 字,大约阅读时间需要 8 分钟。

性能测试入门

上一章节我们大概了解了 LoadRunner,这一章我们来认识一下性能测试。

什么是性能测试?

性能测试是通过自动化测试工具模拟多种正常、峰值以及异常负载条件,对系统的各项性能指标进行测试。简单来说,性能测试就是通过模拟各种使用场景,观察系统在高负载、资源紧张等极端条件下的表现,找出性能瓶颈并提出优化建议。

性能测试有哪些类型?

性能测试的类型多种多样,每种类型都有其独特的目的和应用场景。以下是几种常见的性能测试类型及其特点:

  • 负载测试(Load Testing)

    • 定义:在被测系统上不断增加压力,直到性能指标(如响应时间)超过预期指标或者某种资源使用已经达到饱和状态。
    • 特点:
      • 主要目的是找到系统处理能力的极限。
      • 需要考虑被测系统的业务压力量和典型场景。
      • 通常用于了解系统的性能容量,即系统在保证一定响应时间的情况下能够允许多少并发用户的访问。
  • 压力测试(Stress Test)

    • 定义:系统在一定饱和状态下,例如CPU、内存等饱和情况下,系统能够处理的会话能力,以及系统是否会出现错误。
    • 特点:
      • 该方法的主要目的是检查系统处于压力情况下是应用的性能表现。
      • 通过增加访问压力,使得系统资源使用保持在一定水平,检验此时应用的表现。
      • 一般通过模拟负载等方法,使得系统的资源使用达到较高的水平。
  • 验收性能测试

    • 定义:特定条件下验证系统的能力状况。
    • 特点:
      • 主要目的是验证系统是否具有系统宣称的能力。
      • 需要事先了解被测系统的典型场景,并具有确定的性能目标。
      • 需要在已确定的环境下进行。
  • 配置测试

    • 定义:通过对被测系统软硬件环境的调整,了解各种不同环境对系统性能影响的程度。
    • 特点:
      • 主要目的是了解各种不同因素对系统能力影响的程度。
      • 一般在对系统性能状况有初步了解后进行。
      • 需要在确定的环境、操作步骤和压力条件下进行。
  • 并发测试

    • 定义:模拟多用户并发访问同一个应用、模块或者数据记录时是否存在死锁或者其他性能问题。
    • 特点:
      • 主要目的是发现系统中可能存在的并发访问时的问题。
      • 主要关注系统中可能存在的并发问题,如内存泄漏、线程锁和资源争用等。
      • 可以在开发的各个阶段使用,需要相关的测试工具的配合和支持。
  • 可靠性测试

    • 定义:给系统施加一定的业务压力,让其持续运行一段时间,测试在这种条件下能否稳定运行。
    • 特点:
      • 主要目的是验证系统是否支持长期稳定的运行。
      • 需要在压力下持续一段时间的运行。
      • 测试过程中需要关注系统的运行情况,如内存使用、其他资源的使用以及响应时间有无明显变化。
  • 失效恢复测试

    • 定义:针对有多余备份和负载均衡的系统设计。
    • 特点:
      • 主要目的是验证局部故障下系统能否继续使用。
      • 需要指出问题发生时“能支持多少用户访问”和“采取何种应急措施”。
      • 一般只有对系统持续运行能力有明确指标的系统才需要该类型测试。
  • 容量测试(Volume Testing)

    • 定义:通过性能测试,如果找到了系统的极限或苛刻的环境中系统的性能表现,在一定的程度上,就完成了负载测试和容量测试。
    • 特点:容量还可以看作系统性能指标中一个特定环境下的一个特定性能指标,即设定的界限或极限值。
  • 基准测试

    • 定义:通过设计科学的测试方法、测试工具和测试系统,实现对一类测试对象的某项性能指标进行定量的和可对比的测试。
    • 特点:需要通过科学的测试方法和工具,设计出精确的测试场景,确保测试结果具有可比性。
  • 大数据量测试

    • 定义:针对某些系统存储、传输、统计查询等业务进行大数据量的测试。
    • 特点:主要针对存储、传输、统计等业务场景,模拟大规模的数据量,测试系统在大数据环境下的表现。
  • 疲劳强度测试

    • 定义:长时间对目标测试系统加压,目的是测试系统的稳定性,持续时间一般在1小时以上。
    • 特点:与可靠性测试相似,主要通过长时间的高负载测试,验证系统在长时间运行中的稳定性。
  • 性能测试流程

    性能测试是一个系统性工程,通常包括以下几个步骤:

  • 需求分析

    • 需求分析是软件测试关键步骤之一,通过需求分析,我们能够了解到软件要提供的能力,方便后续开展测试工作。性能测试作为软件测试的一部分,需求分析同样重要。
    • 通过需求分析,我们可以明确测试的方向。比如,性能测试的测试策略、工具选型、性能指标等都需要通过分析才能得出。
  • 测试准备

    • 通过了需求分析,我们明确了测试的方向。那么,我们就要做好工具、环境部署、用例脚本等一些前提准备。
    • 这包括选择合适的测试工具(如LoadRunner、JMeter等)、配置测试环境、编写测试用例脚本等。
  • 测试执行

    • 一切准备好了,性能测试理所当然走到了测试执行的环节。测试的执行我们可以人工干预方式执行,也可以无人值守方式执行(自动化性能测试)。
    • 在测试执行过程中,需要监控系统的性能指标,如响应时间、CPU使用率、内存使用量等,确保测试过程中系统的稳定性。
  • 结果分析

    • 测试执行完成后,就到了我们性能测试的目的关键步骤了 - 性能结果分析。我们性能测试目的是改善系统的性能,达到客户规定的指标。
    • 通过对测试结果的分析,可以找出系统性能的瓶颈问题所在,指导系统优化和性能调优工作。
  • 总结与报告

    • 结果分析完了,接下来是总结与报告。报告需要提交给客户方、产品方或相关利益方阅读,同时也需要保存好作为后续问题处理的参考资料。
    • 报告应包括测试用例设计、测试结果分析、问题定位及优化建议等内容。
  • 常见的性能测试工具

    性能测试工具是性能测试工作中不可或缺的一部分,常用的性能测试工具包括:

  • LoadRunner

    • 功能完整强大,但内存占用较大,需要收费。
    • 适用于大型企业级系统的性能测试,支持多种协议和应用场景。
  • JMeter

    • 开源免费,免费使用,操作简单易懂。
    • 适用于日常性能测试工作,支持多种测试场景和协议。
  • 其他工具

    • 还有一些其他的性能测试工具,如Automic、Blaze、PerformanceTest等,这些工具各有其特点,适用于不同的测试场景和需求。
  • 通过合理选择和使用性能测试工具,可以更高效地完成性能测试工作,提升测试效率和准确性。

    转载地址:http://ymbl.baihongyu.com/

    你可能感兴趣的文章
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>