- 性能的参考指标
- 执行时间 -- 从代码开始运行到结束的时间
- CPU时间 -- 函数或者线程占用CPU的时间
- 内存分配 -- 程序在运行时占用内存的情况
- 磁盘吞吐量 -- 描述IO的使用情况
- 网络吞吐量 -- 描述网络的使用情况
- 响应时间 -- 系统对某用户行为或者时间做出的响应时间
- 性能的瓶颈资源可能有:
- 磁盘IO
- 网络操作
- CPU
- 异常 -- 对Java应用来说,异常的补货和处理是非常消耗资源的,如果程序高频率的对异常处理会对整体性能有影响
- 数据库
- 锁竞争 -- 增加上下文切换的开销
- 内存
- 性能调优的层次
- 设计调优 -- 宏观调优,开发之前设计出合理方案,直接决定产品品质,能事先规避问题。设计优化时,设计人员要熟悉设计方法,设计模式,基本性能组件和常用的优化思想。
- 代码调优 -- 微观调优,注重实现方式的性能差异
- JVM调优 -- 开发后期记性,需要对JVM的运行原理和基本内存结构有一定的了解。如果堆内存的结构,GC的种类等
- 数据库调优
- 应用层对SQL语句进行优化 -- SQL语句的优化
- 对数据库进行优化 -- 设计良好的表结构
- 对数据库软件进行优化 -- 例如设置合理大小的共享池,缓存缓冲区或者PGA等
- 操作系统调优 -- 比如UNIX中共享内存段,信号量,共享内存最大值等
时间: 2024-10-12 03:24:50