1、Java性能调优概述

  1.1、Web服务器,响应时间吞吐量是两个重要的性能参数。

  1.2、程序性能的几个表现:

    • 执行速度:程序的反映是否迅速,响应时间是否足够短
    • 内存分配:分配是否合理,是否过多地消耗内存或泄露
    • 启动时间:程序从运行到可以正常处理业务需要花费多长时间
    • 负载承受能力:当系统压力上升时,系统的执行速度、响应时间的上升曲线是否平缓

  1.3、木桶原理与性能瓶颈

    根据木桶原理,系统的最终性能取决于系统中性能表现最差的组件。

    有可能成为系统瓶颈的计算资源:

      磁盘I/O:

      网络操作:

      CPU:

      异常:

      数据库:

      锁竞争:

      内存:

  1.4、Amdahl定律

    加速比=优化前系统耗时/优化后系统耗时

    设加速比为Speedup,必须串行化的程序比重为F,CPU处理器数量为N,则有:

    

    为了提高系统的速度,仅增加CPU处理器的数量并不一定能起到有效的作用,需要从根本上修改程序的串行行为,提高系统内可并行化的模块比重,在此基础上,合理增加并行处理器数量,才能以最小的投入,得到最大的加速比。

  1.5 性能调优的层次

    设计调优:软件开发之前;所有调优手段的最上层,对软件整体质量有决定性的影响。可以规避某一个组件的性能问题,而非改良该组件的实现。(需要熟悉:常用软件设计方法、设计模式、基本性能组件、常用优化思想)

    代码调优:开发过程中或开发完成后;从微观上对性能的调整,是产生最直接影响的优化方法。熟悉相关的API,对算法、数据结构的灵活使用。

    JVM调优:开发后期;对JVM的运行原理和基本内存结构有一定了解,然后根据程序特点,设置合理的JVM启动参数。

    数据库调优:分为3个部分

      应用层对SQL语句优化:编程技巧,指定列名避免使用*、使用PreparedStatement代替Statement等

      数据库进行优化:冗余字段、水平切割、索引等

      数据库软件进行优化:以Oracle为例,合理的共享池、缓存缓冲区或者PGA等

    操作系统调优:linux,共享内存段、共享内存最大值、最小值、虚拟内存大小、磁盘的块大小等;wiindows,虚拟内存等

  1.6基本调优策略和手段

    优化的一般步骤:首先明确性能目标,指出优化的对象和最终目的。其次,在目标平台对软件进行测试,通过各种性能监控和统计工具,观测和确认当前系统是否已经达到相关目标,若已经达到,则不再优化;若未达到,则需要查找当前的性能瓶颈。

    注意事项:不能为了优化而优化,需要进行慎重的评估。

2、设计优化

  2.1、设计模式

    2.1.1 单例模式

      频繁使用的对象,可以省略创建对象所花费的时间。

      由于new操作的次数减少,对系统内存的使用频率也会降低,减轻GC压力,缩短GC停顿时间。

      延迟加载、多线程环境(内部类):

public class StaticSingleton{
private StaticSingleton(){
System.out.println("create");
}
private static class SingletonHolder{
private static StaticSingleton instance = new StaticSingleton();
} public static StaticSingleton getInstance(){
return SingletonHolder.instance;
}
}

      反射机制,强行调用单例类的私有构造函数,生成多个单例。

      程序的序列化和反序列化可能会破坏单例。

    2.1.2 代理模式

      原因:安全方面,屏蔽客户端直接访问真实对象;提升系统性能,对真实对象封装,从而达到延迟加载;远程调用中,处理远程方法调用的技术细节。

      动态代理:使用字节码动态生成加载技术,在运行时生成加载类。

       方式:JDK自带的动态代理、CGLIBJavassist或者ASM库。  

    2.1.3 享元模式

      目的:提高系统性能,复用大对象,节省内存空间和对象创建时间

      核心思想:在一个系统中存在多个相同的对象,那么只需共享一份对象的拷贝,而不必为每一次使用都创建新的对象。

      几个概念:享元工厂、抽象享元、具体享元类、Main

      SAAS、租户

      享元模式和对象池:享元对象不可相互替代,对象池中的对象都是等价的。

        

    

    

Java程序性能优化——让你的java程序更快、更稳定的更多相关文章

  1. 《Java程序性能优化:让你的Java程序更快、更稳定》

    Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧

  2. 笔记《Java程序性能优化 让你的Java程序更快、更稳定》 第二章 设计调优

    2.1 善用设计模式 23 (1) 1. 设计模式好处: 2.1.1 单例模式 23 (6) 1. 单例模式是一种对象创建模式,用于产生一个对象的具体实例,它可以确保系统中一个类只产生一个实例: 2. ...

  3. Java程序性能优化技巧

    Java程序性能优化技巧 多线程.集合.网络编程.内存优化.缓冲..spring.设计模式.软件工程.编程思想 1.生成对象时,合理分配空间和大小new ArrayList(100); 2.优化for ...

  4. [JAVA] java程序性能优化

    一.避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. 例子: import java.util ...

  5. Java程序性能优化读书笔记(一):Java性能调优概述

    程序性能的主要表现点: 执行速度:程序的反映是否迅速,响应时间是否足够短 内存分配:内存分配是否合理,是否过多地消耗内存或者存在内存泄漏 启动时间:程序从运行到可以正常处理业务需要花费多少时间 负载承 ...

  6. Java程序性能优化之性能概述

    性能的基本概念 一).什么叫程序的性能? 程序运行所需的内存和时间. 二).性能的表现形式: 1).执行速度: 程序的反应是否迅速,响应时间是否足够短. 2).启动时间:程序从运行到可以处理正常业务所 ...

  7. Java的性能优化

    http://www.toutiao.com/i6368345864624144897/?tt_from=mobile_qq&utm_campaign=client_share&app ...

  8. Java GC 专家系列5:Java应用性能优化的原则

    本文是GC专家系列中的第五篇.在第一篇理解Java垃圾回收中我们学习了几种不同的GC算法的处理过程,GC的工作方式,新生代与老年代的区别.所以,你应该已经了解了JDK 7中的5种GC类型,以及每种GC ...

  9. 从虚拟机视角谈 Java 应用性能优化

    从虚拟机视角谈 Java 应用性能优化 周 祥, 软件工程师, IBM 简介:Java 的普及和广泛应用,以及其基于虚拟机运行的机制,使得性能问题越来越重要.本文从 Java 虚拟机的角度,特别是垃圾 ...

随机推荐

  1. .net服务端信息

    if (Session["wolf"]==null) { Session["wolf"] = Guid.NewGuid(); } Label0.Text = & ...

  2. 25M电子琴实现

    module qin(input clk,output reg beep,input [3:0] col,output [3:0] row_data,output [7:0]out ,input rs ...

  3. IEEE829-2008软件测试文档标准介绍

    1998版中定义了一套文档用于8个已定义的软件测试阶段: 测试计划: 一个管理计划的文档 包括:   测试如何完成 (包括SUT的配置).   谁来做测试   将要测试什么   测试将持续多久 (虽然 ...

  4. 【转】微信小程序给程序员带来的可能是一个赚钱的机遇

    自上周被微信小程序刷屏之后,这周大家都在谈微信小程序能够带来哪些红利的话题,其实我想从程序员的角度来谈谈,带给我们程序员来的红利,或许是我们程序员创业或者赚钱的机遇. 其实我从<作为移动开发程序 ...

  5. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(24)-权限组的设计和实现(附源码)(终结)

    ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2):数据库访问层的设计Demo    (3):面向接口编程   (4 ):业务逻辑层的封装    ...

  6. Tomcat的下载和配置

    目录结构: // contents structure [-] 下载Tomcat 配置Tomcat 运行Tomcat 参考文章 下载Tomcat 读者可以到apache官网下载Tomcat.笔者下载的 ...

  7. 转发:Chrome 控制台console的用法

    大家都有用过各种类型的浏览器,每种浏览器都有自己的特色,本人拙见,在我用过的浏览器当中,我是最喜欢Chrome的,因为它对于调试脚本及前端设计调试都有它比其它浏览器有过之而无不及的地方.可能大家对co ...

  8. 理解CSV文件以及ABAP中的相关操作

    在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...

  9. dojo.require()的相关理解

    Dojo 提供了一个非常强大的javascript控件库. 在使用dojo之前,用户基本上不需要具备任何基础知识. 你可以用script远程链接到dojo(dojo.js), 也可以把dojo.js下 ...

  10. 数据结构->直接插入排序

    数据结构->直接插入排序 实现效果 从小到大排序 算法原理 有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序. 算法步骤 从第一个元素开始,该元 ...