Java性能调优概述

1.1 性能概述

程序性能通过以下几个方面来表现:

1. 执行速度;

2. 内存分配:内存分配是否合理,是否过多地消耗内存或者存在泄漏;

3. 启动时间;

4. 负载承受能力:当系统压力上升时,系统的执行速度、响应时间的上升曲线是否平缓;


性能的参考指标

1. 执行时间;

2. CPU时间;

3. 内存分配;

4. 磁盘吞吐量;

5. 网络吞吐量;

6. 响应时间。

注:主要体现在时间、空间和速度匹配三个方面。


系统的最终性能取决于系统中性能表现最差的组件,因而形成性能瓶颈。最有可能成为系统瓶颈的计算资源如下:

1. 磁盘I/O;

2. 网络操作;

3. CPU(对计算资源要求较高的应用);

4. 异常(异常的捕获和处理是非常消耗资源的);

5. 数据库(海量数据的读写);

6. 锁竞争(线程上下文切换的成本);

7. 内存(高频率的内存交换与扫描)。


Amdahl定律:串行系统并行化后加速比的计算公式和理论上限。

使用多核CPU对系统进行优化,优化的效果取决于CPU的数量以及系统中的串行化程序的比重。


性能调优的层次

1. 设计

设计调优对系统性能的影响是最大的,它直接决定了系统的整体品质。因此,尽可能多花时间在系统设计上。

设计优化的一大特点是,它可以规避某一个组件的性能问题,而非改良该组件的实现。

2. 编码

代码调优可在软件开发过程中,或者再软件开发完成后,软件维护过程中进行。需要开发人员熟悉相关语言的API,并在合适的场景中正确使用相关API或类库。同时,对算法、数据结构也能灵活使用。

3. 运行时调优

A. JVM调优

JVM的各项参数直接影响Java程序的性能。需要开发人员对JVM的运行原理和基本内存结构有所了解,进而根据程序的特点,设置合理的JVM启动参数。

B. 数据库调优

分为三部分:

-在应用层对SQL语句进行优化(涉及大量的编程技巧);

-对数据库进行优化(主要是建立一个良好的表结构数据库);

-对数据库软件进行优化(以Oracle为例,设置合理大小的共享池、缓存缓冲区或者PGA)。

C. 操作系统优化


优化的一般步骤



性能优化注意事项

软件优化需要考虑人力成本,需要在软件功能、正确性和可维护性之间取得平衡。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值