0


真的是性能优化(压测)-纯思想

文章目录

概要

性能优化是一个持续的过程,需要监控、评估、调整以及不断测试。
利用性能监控工具,结合日志分析,可以对上述指标进行度量和分析,从而发现和解决性能瓶颈。

在进行压测时,不应该仅针对单一接口进行测试,因为系统是一个统一的整体,包含众多互相作用的部分。
测试应该基于真实用户行为对一系列用户场景(包含多个接口)进行模拟,以此来反映用户的真实操作流程。
因此,在项目开发中,了解并模拟用户真实行为是进行有效性能压测的重要条件。

一般而言,由于很多应用程序是读密集型的,因此压测更侧重于模拟查询操作。但是,写操作(包含新增、删除和修改)同样应该纳入压力测试的范畴,尽管这可能会涉及到更多的成本和资源考虑。因为写操作通常伴随着事务处理、锁定机制、数据一致性和安全性等挑战,因此对这些操作的测试不可忽视。如果不进行这些操作的测试,可能会导致生产环境下未被发现的性能瓶颈或问题。

在进行写操作的性能测试时,需要制定策略来管理数据的一致性和完整性。例如,可以在独立的测试环境中进行测试,并确保有数据备份和恢复的机制,以防测试引起数据错乱或丢失。这样的措施可以帮助准确评估应用程序在高负载情况下的表现,同时保护测试环境的数据安全。

 提示:但是实际开发过程中仅仅是对查询做压测的比较多一些,增删改相对较少

主要原因有:

  • 查询优先:很多应用(尤其是读多写少的系统,如新闻、视频平台)有更高的查询请求比例,因此查询操作的性能对整体系统性能影响更大,从而成为压测的重点。
  • 数据一致性和完整性:增删改操作往往涉及数据的变更,如果在没有充分准备的情况下进行大量写操作的压测,可能会导致测试环境数据的混乱,影响测试的准确性。
  • 成本和资源考虑:增删改操作可能涉及复杂的事务处理、锁定机制、数据备份等,这些都是资源密集型的操作。在测试环境模拟高负载的写操作可能需要额外的资源和成本,例如备份和还原数据的机制,以确保测试后系统可以返回到稳定的状态。
  • 风险管理:写操作还可能引起数据丢失或损坏的风险,所以需要特别小心地对待。

优化指标-MD都是文字看看就行

用户体验层:直接关乎用户感知的指标。

  • 响应时间和延迟:用户感知到的页面加载或交互反馈时间。
  • 错误率:用户遇到的错误数量(页面加载失败、功能不可用等)。

应用性能层:影响应用运行的关键性能指标。

  • 吞吐量:整个应用能够处理的请求数量。
  • 并发用户数:系统能够支持的同时在线用户数量。
  • 缓存命中率:反映了缓存策略的有效性,影响响应速度和后端压力。

资源利用层:反映了系统对硬件资源的使用情况。

  • CPU使用率:CPU的占用情况,过高可能表示计算瓶颈。
  • 内存使用量:系统对物理内存和堆内存的占用情况。
  • 磁盘I/O:反映了磁盘读写的压力,I/O密集型的应用这是一个重要指标。
  • 网络I/O:网络数据传输的压力情况。

稳定性和可靠性层:直接影响服务的持续可用性。

  • 服务水平协议(SLA)指标:包含可用性、性能、性能等级,直接反映服务的可靠性和用户的期望。
  • 系统吞吐量:在稳定性的前提下,系统能持续处理的最大数据量。
  • 队列长度:系统中排队等待的任务数量,反映了系统负载和处理能力。

垃圾回收和内存管理层:影响应用性能和稳定性的底层机制。

  • 垃圾回收次数和暂停时间:频繁或不当的垃圾回收会影响应用的性能。
  • 内存泄露:随着运行时间的累积可能会导致应用奔溃,影响稳定性。

数据存取层:通常与数据库和数据存储相关。

  • 数据库性能:包括查询性能、锁定竞争、索引效率等,直接关系到应用的数据处理能力。

性能优化操作

1、代码优化:

  • 算法与逻辑优化
  • 代码结构重构
  • 数据访问和持久化
  • 缓存机制
  • 并发控制和锁优化
  • 异常处理和资源管理

2、系统配置与环境优化:

  • JVM配置调优(内存设置、垃圾收集调优等)
  • 应用服务器优化(线程池、连接池等)
  • 操作系统调优(网络参数、I/O优化等)
  • 数据库优化(索引、查询优化、配置参数等)
  • 中间件配置(消息队列、缓存服务器等)

3、架构与设计:

  • 系统架构(微服务、分布式设计、服务拆分等)
  • API设计与优化(RESTful、gRPC等)
  • 负载均衡与扩展性
  • 静态内容分发(CDN使用、资源压缩等)

4、实施与监控:

性能测试(基准测试、压力测试等)
监控、警报和日志分析(应用监控、数据库监控等)
自动化和持续集成
安全性与合规(避免引入性能开销大的安全检查)

5、开发流程和环境管理:

代码审查流程
敏捷开发与迭代
版本控制和代码合并策略
环境一致性(开发、测试、生产环境保持一致)

总结

若是有不足的地方还希望能指出来,共同完善,不胜感激
路虽远,行则将至,事虽难,作则必成
总想做好这件事情,但是奈何自己能力有限,古话讲
一个好汉三个帮,一个篱笆三个桩。希望能遇到志同道合的朋友
在这里插入图片描述


本文转载自: https://blog.csdn.net/sutingStart/article/details/136257943
版权归原作者 苏汀star 所有, 如有侵权,请联系我们删除。

“真的是性能优化(压测)-纯思想”的评论:

还没有评论