美文网首页
分布式应用异常测试一二说

分布式应用异常测试一二说

作者: 思考的犀牛 | 来源:发表于2017-11-27 16:56 被阅读12次

       异常测试按性质分为应用层的业务逻辑异常测试、系统硬件/网络/文件/数据库/缓存/中间件异常测试,其中包含了许多的场景(单机、分布式),但所有的场景均和这两项有直接的关系。

      业务逻辑异常测试体现在当上述的第二种异常发生时,是否能根据业务的需要或者架构的设计做出合理的业务处理反应,这是建立在第二种异常测试之上的,因此异常测试的关系也已经非常明确了,第一种测试根据业务的不同,范围和流程有不确定性,第二种测试则是在一些明确的规则和约定下进行。

       当架构演进到分布式,往往在测试过程中给人无从下手的错觉,尤其在异常测试方面,其实不然,前面提到的单机和分布式看似是两种类型,单独看,单机的异常影响范围可能会小一些,但事实上他们在分布式环境中会产生互相影响:

       单机:从系统层面来说就是指单一进程,从异常测试角度来看,影响范围发生在线程或进程级别,线程级别的异常可能导致线程的结束,且没有启动新的线程来代替,进程级别可能导致线程锁的不释放,导致其他线程都挂起等待。

       分布式:分布式是一个协同工作的应用环境,这种异常往往容易引起其他进程的挂起,或者数据库、缓存、中间件的问题,主要有网络调用所占用的资源、数据库访问等。

       单机的异常如果处理不当,会引起整个环境中的资源不可用,从而导致环境中的每个单机都出现异常。根据上述的一些概念,可以列出异常测试中最重要的一些场景:

系统资源:cpu、内存使用率过高,能否能将请求切到到资源利用率低的服务器上;


数据量大小和形式:数据到底应该注入多少满足后续的压力测试,各服务对数据格式的要求和转换;


文件读写:

本地写:对同一个文件打开的的数量过多,或者只打开不关闭,导致文件句柄数超过系统阈值;

本地读:打开一个不存在的文件,是否有对应处理逻辑;

网络存储:服务不可用;


应用连接:

短连接:请求方未设置超时时间,长时间等待响应方的响应,从而导致请求的大量堆积,线程池的处理线程被用完,导致大量新的用户请求被拒绝;

长连接:在网络出现异常状况后,断开的连接是否能重新建立,请求方如拿到失效的连接,是否能处理异常;


数据库:

数据源切换:如果所切换的数据源连接处于不可用状态或宕机时,是否会长时间等待或重试;

表锁、行锁:长时间更新操作,导致其他对此表的修改操作被挂起;

慢SQL的预防:通过对SQL的提前分析,来预防慢SQL相关的问题,及时告知DBA进行优化;


缓存:

key的失效:在获取不到key后,是否能正常处理;

锁的释放:申请到锁的一方如果意外重启,是否能在重启后释放锁;

缓存服务不可用;


消息中间件:

消息记录表切换:是否丢失;

清除消息记录:是否丢失记录;


服务发现:

服务不可用:是否有其他处理措施;

单台不可用:是否能重新选举,重新建立连接;


应用容器:

连接数:配置优化;

请求处理线程:配置优化;

jvm堆栈大小:参数优化;


前端静态化页面:

后端服务不可用;

缓存不可用;


数据库中间件:

数据访问是否在错误发生后进行了正确的转移;

对于上层业务来说是否进行了正确的向下隔离;

相关文章

  • 分布式应用异常测试一二说

    异常测试按性质分为应用层的业务逻辑异常测试、系统硬件/网络/文件/数据库/缓存/中间件异常测试,其中包含了许...

  • 异常测试平台搭建

    异常测试是有别于功能测试和性能测试又一种测试类型,通过异常测试,可以发现由于系统异常、依赖服务异常、应用本身异常等...

  • 1. 模块做异常测试考虑点

    ###关于异常测试### 异常测试就是人为地构造异常场景,观察服务在异常场景下的表现是否符合预期。 常见异常测试类...

  • Jmeter之分布式测试

    meter之分布式测试 2017年10月27日 15:20:57 由于(1)Jmeter 是纯java 应用,对于...

  • java自动化(二)接口的用例设计

    接口测试范围? 功能测试 异常测试: 性能测试: 自动化接口测试范围? 功能测试+数据异常测试 接口测试用例设计?...

  • Jmeter分布式部署

    Jmeter分布式部署 在使用Jmeter进行接口的性能测试时,由于Jmeter是JAVA应用,对于CPU和内存的...

  • GO 微服务GO-Micro(18)-(按自己理解做笔记)ope

    为什么需要链路追踪 分布式服务下,请求链路信息统计,应用请求分析,和异常信息定位。把每一次分布式的请求变为成可视化...

  • 取消书面考试

    早上到校后校长突然通知说一二年级不组织书面考试,让一二年级的老师们根据要求自行准备测试。 不让一二年级的考试,一二...

  • 分布式应用

    常见分布式应用实现方案: 1)Spring Cloud构建分布式应用 2)基于ICE构建分布式应用 3)基于消息中...

  • TestNG运行结果分析与失败截图功能介绍

    TestNG测试结果 一、成功、失败和断言: 如果一个测试没有抛出任何异常就完成运行或者说抛出了期望的异常 此时,...

网友评论

      本文标题:分布式应用异常测试一二说

      本文链接:https://www.haomeiwen.com/subject/edpdbxtx.html