zoukankan      html  css  js  c++  java
  • 服务端稳定性测试

    https://blog.csdn.net/huazhongkejidaxuezpp/article/details/89632907

    本文链接:https://blog.csdn.net/wodeyijia911/article/details/89632907
    目录

    一、什么是稳定性

    二、稳定性测试方法

    方法一:线下稳定性测试通常的做法

    关注指标:

    测试注意事项

    方法二:线上监控/线上巡检

    三、故障模拟测试在提升系统稳定性中的实际应用

    四、客户端稳定性测试

    一、什么是稳定性
    稳定性定义:系统长期稳定运行能力,需要时间累积才能度量

    潜在的问题:某些系统问题,只有在一天、一星期甚至更长的时间才会暴露的问题。比如:内存泄漏问题

    二、稳定性测试方法
    稳定性测试整体思路:一定负载下,持续运行长时间,验证系统是否可以正常提供服务。

    稳定性测试的边界:稳定性测试本质上仍然属于概率测试。即即使稳定性测试通过了,也不能保证系统100%没有稳定性问题了。实际项目中,要尽可能的提高测试的可靠性,可以通过多次测试,延迟测试时间、加大流量/并发等,来尽可能多暴露问题,来提高测试的可靠性。

    影响稳定性测试的考虑因素:

    时间:是否需要不间断连续运行?长时间运行是否会有数据累积或者资源泄露?如测试稳定性,推荐测试时间 8小时以上

    大流量:哪些模块、数据和流量有关?极限流量下系统还能正常吗?

    大并发:正常逻辑业务的大并发以及操作冲突任务的并发下是否都能正常?

    环境:系统运行的环境如何?负载高、网络延迟、抖动等是否会影响系统正常工作?

    使用方式:用户真正的配置及使用模式和测试是否类似?

    极端情况:宕机、服务被kill等系统是否高可用?

    方法一:线下稳定性测试通常的做法
      长时间对系统施压,观察系统的各种性能指标,以及服务器的指标。例如,观察系统的各种监控指标曲线,预测系统的发展状况。响应时间是否有增长,可用内存是否在减少,CPU利用率是否在上升等等都可以说明系统是否存在问题

    1)模拟线上长时间运行的情况:模拟平常的压力,模拟实际中日常的用户数进行操作

    2)模拟的具体工具:可以使用通常的性能测试工具

    3)测试的时间:每次有影响稳定性方面的修改时,上线前进行,并将稳定性测试作为一项常规测试。比如:为了管理稳定性测试的整个生命周期,上线前回归自动触发稳定性测试脚本,平台展示和通知稳定性测试结果

    4)故障演练

    目标:模拟强依赖,弱依赖服务异常情况下,本系统可正常提供服务的能力

    模拟异常情况:

    模拟下游超时,延时情况下不被下游依赖服务拖垮
    强依赖的服务异常/超时时,其他非依赖的核心服务仍然正常
    系统实现合理性。比如,sso数据是否需要实时获取,可以模拟SSO挂掉了,公司wiki业务还正常,但系统完全不可用了
    中间件的异常(消息服务、数据库服务、缓存服务)
    模拟集群中一台主机突然出现CPU飙升、物理内存不足、网络不通等问题,是否还可以稳定地对外提供服务
    关注指标:
    关注系统指标:

    如果是CPU密集型,重点关注CPU占用率,e.g.报价系统

    如果是内存密集型,重点关注内存占用率,e.g.搜索引擎Elastic Search

    如果是网络IO密集型,关注网络IO情况,e.g.消息队列相关系统,是否存在消息堆积等

    测试注意事项
    ps: 稳定性测试、性能测试均需要注意

    1)内部数据污染

    该服务对数据库的依赖、缓存依赖, 是否只读, 会不会对线上数据造成污染

    如涉及写操作,请提前联系DBA准备数据源

    2)外部数据污染

    该服务对外部接口/服务有依赖,是否只读, 会不会对线上数据造成污染

    3)业务方影响

    外部服务(业务方)对本服务的依赖,压测过程中是否影响业务方,是否周知到业务方

    4)降级方案&监控报警

    当压力过大时,降级方案或措施是什么,是否有监控报警 

    5)压测基本信息

    明确机器、具体接口、并发数、测试时间段(必须在业务流量低峰期)、预期目标、关注的指标

    方法二:线上监控/线上巡检
    监控/巡检属于后置行为了,即保证如果问题发生,可以及时发现/暴露出来。

    三、故障模拟测试在提升系统稳定性中的实际应用
    目标:通过故障模拟测试发现很多影响系统稳定性的问题

    分类

    具体问题

    依赖服务

    1.事务中包含外部调用

    2.弱依赖服务故障影响交易核心链路,不符合预期(代码缺陷)

    3.超时问题:只设置读超时未设置连接超时、上下游超时时间设置不合理、超时重试次数不合理

    4.熔断参数设置不合理,未按照预期熔断

    5.限流后未正常触发报警

    基础组件(消息队列、缓存等)

    1.缓存降级方案失效,未按预期降级到本地缓存(代码缺陷)

    2.消费者未对错误、过期、重复的MQ进行处理

    3.Leaf、MQ等存在单点风险,没有容灾处理

    4.缓存恢复后放量没有预热,一次性放量导致响应超时

    数据库

    1.全部强制读主库(允许延迟的场景需要优先读从库,减轻主库压力)

    2.主从延迟敏感的场景未强制读主库(交易核心链路中的回调场景)

    核心全链路系统验证

    1.系统未对下游的回调请求进行限流,下游故障恢复后,大量请求涌入,将系统打挂了(故障恢复后,服务无法自恢复

    四、客户端稳定性测试
    通过Monkey测试App稳定性:它通过发送一系列伪随机的用户事件流进行压力测试

    例如,将IOS云测上的稳定性测试接入jenkins,可以持续地进行IOS稳定性测试,便于更好地发现问题
    ————————————————
    版权声明:本文为CSDN博主「多则惑少则明」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/huazhongkejidaxuezpp/article/details/89632907

  • 相关阅读:
    “测试建模——21世纪视角”的幻灯片
    Test@Office: 每周测试会议
    用Excel展示SQL Server中的数据 (II): 宏与自动化
    Test in Production: Bing主页图片与Like
    测试建模:功能列表(Function List)
    探索式测试:肥皂剧测试(Soap Opera Testing)
    我辈再临,究极为何?
    测试建模:启发式测试策略模型(Heuristic Test Strategy Model)
    用Excel展示SQL Server中的数据 (I): 数据库连接
    Altera LVDS IP的应用
  • 原文地址:https://www.cnblogs.com/ceshi2016/p/11673879.html
Copyright © 2011-2022 走看看