Jmeter 压测-性能调优5大注意

 

性能调优主要涉及这些方面:

代码、数据库、网络、硬件、系统构架

1、代码

①缓存

  1. 缓存是典型的空间换时间,在软件项目中,用的最多的是redis缓存,第一次查询的时候,将查询数据存储到缓存中。

  2. 后面每次查询,先从缓存中取数据,缓存中没有,再去数据库中取数据。

②多线程&多进程

使用多线程,缩短任务时间

③异步

  1. 针对某些客户端的请求,在服务端可能需要针对这些请求做一些附属的事情

  2. 这些事情其实用户并不关心或者用户不需要立即拿到这些事情的处理结果

  3. 这种情况就比较适合用异步的方式处理这些事情。

作用:缩短接口响应时间,使用户的请求快速返回,用户体验更好。

④批处理

是把一堆基本相同的请求批量处理,这样可以一批数据只写一次数据库,减少数据库的操作次数;

⑤简化代码​​​​​​​

  1. 如:减少循环的层数,减少递归,在循环中少声明变量,少做分配和释放内存的操作,尽量把循环体内的表达式抽到循环外

  2. 条件表达的中的多个条件判断的次序,尽量在程序启动时把一些东西准备好

  3. 注意函数调用的开销(栈上开销)

  4. 注意面向对象语言中临时对象的开销,小心使用异常等。

⑥前端-减少http 请求次数​​​​​​​

  1. 每个http请求从建立到关闭都需要一定的时间,因此减少http请求的数目可有效提高访问性能。

  2. 网页中的的图片、form、flash等等元素都会发出http请求。

⑦前端-减少DNS查询次数​​​​​​​

  1. DNS 的作用是将 URL 转化为实际服务器主机 IP 地址,实现原理是分级查找

  2. 查找过程需要花费 20~100ms 的时间

  3. 所以一方面我们要加快单次查找的时间

  4. 另一方面也要减少一个页面中资源使用了多个不同域的情况;

⑧前端-减少或避免页面跳转

页面跳转相当于又打开一个新的页面,耗费的时间就会比较长,所以要尽量避免使用页面跳转;

⑨前端-减少网页大小

网页过大,如果要快速下载,下载网页内容会需要比较大的带宽,带宽就有可能成为瓶颈。

⑩表单压缩,减少网络传输数据量

典型的时间换空间,虽然压缩消耗时间,但如果瓶颈在网络,用时间换空间反而能节省时间。

⑪使用内容分发网络(CDN)​​​​​​​

  1. 使用 CDN 相当于对静态内容做了缓存,并把缓存内容放在网络供应商(ISP)的机房

  2. 用户根据就近原则到 ISP 机房获取这些被缓存了的静态资源,因此可以大幅提高性能;

2、数据库

①添加/修改索引​​​​​​​

  1. 通过索引查询,缩短查询时间

  2. 通过修改联合索引,增加索引命中率

②分区分库分表​​​​​​​

  1. 不同服务或者不同业务的数据配置不同的数据库,这样在进行增删改查时候可减少数据库磁盘的读写频率。

  2. 备注:分区并不是生成新的数据表,而是将表的数据均衡分摊到不同的硬盘,系统或是不同服务器存储介

③数据库读写分离

从主库写入数据,从库读取数据,减少数据库磁盘的繁忙频率。

④修改数据库连接池

重新定义数据库连接池数,减少任务的排队数量。

⑤硬件配置

提高数据库CPU、内存、磁盘等硬件配置,提升处理能力。

3、网络

调整带宽

4、硬件

①增加机器数量

对于实现了分布式服务,增加服务器数量

②提高硬件配置

提高服务器CPU、内存、磁盘等配置,提高单台服务器的处理能力

③JVM

合理的分配堆与非堆的内存、GC

④中间件

调整ES、MQ中间件的配置架构,如增加中间件机器配置、单机改为分布式

5、系统架构

单机改为分布式集成、负载均衡​​​​​​​

  1. 时间(对于应用服务器而言):软件的响应时间…

  2. 空间(对于硬件服务器而言):服务器的磁盘使用率、CPU使用率、内存空闲率…

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于JMeter分布式压测性能调优,以下是一些建议: 1. 确保服务器性能:确保所有参与分布式压测的服务器都具备足够的硬件资源,包括CPU、内存、磁盘和网络带宽等。这可以避免服务器成为性能瓶颈。 2. 合理设置线程数:在分布式压测中,线程数是一个重要的参数,需要根据服务器性能和测试需求进行合理的设置。过多的线程数可能会导致服务器负载过高,过少则无法发挥最大的压测能力。 3. 优化测试计划:确保测试计划中只包含必要的请求和步骤。删除不必要的请求和断言,减少额外的开销。 4. 合理使用断言:断言是用来验证响应结果的,但过多的断言会增加服务器的负载。只保留必要的断言,并使用高效的断言方式,如使用正则表达式替代XPath。 5. 配置合理的结果收集:JMeter会将每个请求的结果收集起来,这可能会产生大量的数据。合理配置结果收集,包括选择需要收集的数据、设置合理的采样率等。 6. 使用合适的远程启动配置:在分布式压测中,需要配置一个或多个远程服务器来执行测试。确保远程服务器的配置合理,包括JMeter版本一致、Java版本一致等。 7. 启用持久连接:启用HTTP请求中的Keep-Alive选项,可以减少连接的建立和断开次数,提高压测性能。 8. 使用合适的协议:对于不同的压测场景,选择合适的协议,如使用HTTP协议进行简单的Web应用压测,使用JDBC协议进行数据库压测等。 9. 监控和调优:在压测过程中,实时监控服务器的性能指标,如CPU使用率、内存使用率等。根据监控结果进行调优,如适时调整线程数、增加服务器资源等。 以上是一些常见的JMeter分布式压测性能调优建议,根据具体情况和需求,还可以进一步进行优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值