关于压测:浅谈常态化压测-京东物流技术团队

42次阅读

共计 2044 个字符,预计需要花费 6 分钟才能阅读完成。

一、常态化压测介绍

1. 什么是常态化压测

常态是指:“失常的状态”;“化”在这里是示意转变为某种性质或状态。

“常态化”的含意就是:趋势失常的状态。

那么常态化压测顾名思义就能够解释为,让压测趋于失常的状态,趋于正当 ;因而通过调研给了如下定义:常态化压测是指在某个产品或零碎上进行自定义周期(常态化)的、零碎主动执行的、可验证后果的压测过程。目标是检测产品或零碎的稳定性、可靠性和性能,确保它们可能在不同的场景下失常运行。

2. 为什么要进行常态化压测

随着业务的一直增长,撑持业务零碎的压力也逐步减少,会面临如零碎越来越厚重、逻辑越来简单、迭代节奏越来越快等繁冗的状况。咱们以后并没有做到在每次变动时疾速辨认出性能危险,检测产品或零碎的稳定性、可靠性,而且咱们还在一直的投入人力老本在压测这件事件上也是不合理的,所以咱们要将性能验证融入到咱们日常的工作中,把压测做到常态化,做成平时的一件事。

3. 常态化压测的价值

  • 快进快出,最小单位安顿压测工作,缩小人员投入
  • 尽早辨认性能稳定,防止危险后置
  • 可复用性高,压测模型、业务模型可复用
  • 业务可用性保障

[]()

二、常态化压测实际

1. 常态化压测流程介绍

借助泰山平台中的 Forcebot 工具,进行常态化压测执行。设置常态化压测工作,配置压测执行打算,依照预设的数据模型、基线值等进行执行。在累积一段时间的压测后果后,能够对基线值、压测指标进行调整和调优,而后持续进行自动化周期性的压测。同时跟进后果,及时关注最近业务和零碎的变动。

  • 明确压测指标

明确常态化压测的指标,能够辨别日常和极限两个场景。依据不同的场景设置不同的压测指标,第一次实际以单接口的日常流量为主,观测日常流量下的性能稳定,确定失常范畴值。

  • 常态化打算

依据接口的优先级,接口服务的流量,日常迭代代码改变的频率,设置对应的打算。外围接口、流量较大、代码改变频繁的接口,常态化压测的周期倡议短一些,能够一周 1 - 2 次,且放在每次上线后进行;如果是非核心、流量小的接口,能够每周或每双周进行一次。

  • 压测后期筹备

确定测试场景依据理论场景,设计压测场景,包含用户数量、申请类型、申请频率、申请参数等,以尽可能模仿实在的业务场景。编写压测脚本,设置依照实在申请数据比例设置参数化,以便于进行自动化测试。

  • 压测中期关注

在压测过程中,次要是无人值守的状态,所以须要提前辨认压测可能带来的危险,以及面对不同的危险须要采取的措施。

同时还要关注压测过程中如果呈现性能稳定,零碎收回的预警形式是否及时、预警内容是否精确。

  • 压测前期跟进

每次常态化压测打算执行后,都须要关注本次的后果:① 后果合乎预期,则要关注下指标的稳定;② 若后果并不合乎预期,则要刨根问底,找到问题的所在;③ 跟进问题直到解决,解决后从新验证。

[]()

  • 辅助性能 - 流量染色

流量染色指依据流量协定,设置对应的流量染色规定,对指定的流量进行染色标记,并在整个调用链中携带该标记。

通过流量染色,能够实现压测流量隔离,同时能够保障日常压测对生产流量无影响。然而对于常态化压测来讲,流量染色并非必须,而是精益求精的性能,能够进一步保障咱们的流量对生产无影响。

[]()

2. 首次进行常态化压测实际

2.1 筹备阶段

① 获取基线值数据

[]()

② 压测脚本、场景、数据模型筹备

③ 压测环境筹备

④ 压测打算制订

2.2 执行阶段

[]()

[]()

[]()

[]()

2.3 调优阶段

以 7 -10 天为一个周期,记录数据。不思考非凡节日、非凡流动的场景,验证基线数据的可信赖性。如发现高于 30% 的概率,每天的数据都不合乎基线值,可调整基线值的浮动范畴,以保结证后果在日常值的范畴内。

调优的过程也要关注,在数据统计过程中代码的改变,如果确定是代码的改变影响了整体的性能,这就要依据理论的场景和影响范畴进行评估。

2.4 复盘阶段

通过一段时间的常态化压测,须要对整个流程和后果进行复盘,好的复盘后果可能帮忙咱们防止后续的一些“坑”。参加常态化压测的所有人员一起,次要关注一下几个方面:

① 数据是否正确,是否达标,是否可信赖

② 常态化压测流程、打算相干问题

③ 压测过程中的性能问题总结

三、常态化压测总结

① 倡议笼罩场景 能够依据本人所负责的业务进行考量,如果不会呈现很大流量的状况下,倡议笼罩日常场景即可满足需要;如果须要思考大流量并发的场景,倡议笼罩日常的根底上,在笼罩极限的场景。

② 关注危险管制 常态化压测要做到的是模仿生产实在场景,实现日常自动化压测,尽量做到无人值守,所以提前辨认出可能的危险是十分必要的,同时要列出不同的危险项对应的动作。

③ 常态化压测只是辅助验证业务性能的一种伎俩 不是说咱们进行常态化压测之后就不须要进行性能测试了,两者之间是没有抵触的。

寄语:每个人负责的工作是不同的,不同人会有不同诉求,对同一件事也会有不同认识,不过苏轼有句话:“犯其至难而图其至远”,意思是说“向最难之处攻坚,谋求最远大的指标”。只心愿咱们能在工作中克服各种艰难,去实现最久远的、可继续的指标。

作者:京东物流 冯海艳

起源:京东云开发者社区 自猿其说 Tech

正文完
 0