Java 程序性能优化《第一章》Java性能调优概述 1.1性能概述

Java 程序性能调优《第一章》Java性能调优概述(1.1性能概述)

1.1 性能概述

为什么程序总是那么慢?它现在到底在干什么?时间都花在哪里了?也许,你经常会抱怨这些问题,如果是这样,那说明你的程序出了性能问题。和功能问题相比,性能问题在有些情况下,可能不算什么大问题,将就将就,也就过去了。但是严重的性能问题会导致程序瘫痪、假死、直至崩溃。本书就先来认识性能的各种表现和指标。

1.1.1 看懂程序的性能

对客户端程序而言,拙劣的性能会严重影响用户体验,界面停顿、抖动、响应迟钝等问题会遭到用户不停地抱怨。一个典型的例子就是Eclipse IDE工具在Full GC时会出现程序假死的现象,相信一定被不少开发人员所诟病。对于服务器程序来说,性能问题则更为重要,相信不少后台服务器软件都有各自的性能目标。以Web服务器为例,服务器的响应时间、吞吐量就是两个重要的性能参数。当服务器承受巨大的访问压力时,可能出现响应时间变长、吞吐量下降,甚至是抛出内存溢出异常而崩溃,这些问题,都是性能调优需要解决的。

一般来说,程序的性能通过以下几个方面表现:

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

1.1.2 性能的参考指标

为了能够科学的进行性能分析,对性能指标进行定量评测是非常重要的。目前,一些可以用于定量评测的性能指标有:

  • 执行时间:一段代码开始运行到运行结束,所使用的时间。
  • CPU时间:函数或者线程占用CPU的时间。
  • 内存分配:程序在运行时占用的内存空间。
  • 磁盘吞吐量:描述I/O的使用情况。
  • 网络吞吐量:描述网络的使用情况。
  • 响应时间:系统对某用户行为或者事件做出响应的时间。响应时间越短,性能越好。

1.1.3 木桶原理与性能瓶颈

木桶原理又称 ”短板理论“ ,其核心思想是:一只木桶盛水的多少,并不取决于桶壁上最高的那块木头,而是取决于桶壁上最短的那块,如图1.1所示。

图1.1 木桶原理示意图

将这个理论应用到系统性能优化上,可以这么理解,即使系统拥有充足的内存资源和CPU资源,但是如果磁盘I/O性能低下,那么系统的总体性能取决于当前最慢的磁盘I/O速度,而不是当前最优越的CPU或者内存。这这种情况下,如果需要进一步提升系统性能,优化内存或者CPU资源是毫无用处的。只有提高磁盘I/O性能才能对系统的整体性能进行优化。而此时,磁盘I/O就是系统的性能瓶颈。

ps:根据木桶原理,系统的最终性能取决于系统中性能表现最差的组件。因此,为了提升系统整体性能,必须对系统中表现最差的组件进行优化,而不是对系统中表现良好的组件进行优化。

根据应用的特点不同,任何计算机资源都有可能成为系统瓶颈。其中,最有可能成为系统瓶颈的计算资源如下。

  • 磁盘I/O:由于磁盘I/O读写的速度要比内存慢很多,程序在运行过程中,如果需要等待磁盘I/O完成,那么低效的I/O操作会拖累整个系统。
  • 网络操作:对网络数据进行读写的情况与磁盘I/O类似。由于网络环境下的不正确性,尤其是对互联网上数据的读写,网络操作的速度可能比本地磁盘I/O更慢。因此如不加特殊处理,也极有可能成为系统瓶颈。
  • CPU:对计算资源要求较高的应用,由于其长时间、不间断的大量占用CPU资源,那么对CPU的争夺将导致性能问题。如科学计算、3D渲染等对CPU需求旺盛的应用。
  • 异常:对Java应用来说,异常的捕获和处理是非常消耗资源的。如果程序高频率地进行异常处理,则整体性能便会有明显下降。
  • 数据库:大部分应用程序都离不开数据库,而海量数据的读写操作可能是相当费时的。而应用程序可能需要等待数据库操作完成或者返回请求的结果集,那么缓慢的同步操作将成为系统瓶颈。
  • 锁竞争:对高并发程序来说,如果存在激烈的锁竞争,无疑是对性能极大的打击。锁竞争明显会增加线程上下文切换的开销,而且,这些开销都是与应用需求无关的系统开销,白白占用宝贵的CPU资源,却不带来任何好处。
  • 内存:一般来说,只要应用程序设计合理,内存在读写速度上不太可能成为性能瓶颈。除非应用程序进行了高频率的内存交换和扫描,但这些情况比较少见,使内存制约系统性能最可能的情况是内存大小不足,与磁盘相比,内存的大小似乎小的可怜,这意味着应用软件只能尽可能将常用的核心数据读入内存,这在一定程度上降低了系统性能。

1.1.4 Amdahl 定律

Amdahl 定律是计算机科学中非常重要的定律,它定义了串行系统并行后加速比的计算公式和理论上限。

加速比定义 : 加速比 = 优化前系统消耗 / 优化后系统消耗

所谓加速比,就是优化前耗时与优化后耗时的比值。加速比越高,表明优化效果越明显。

Amdahl 定律给出了加速比与系统并行度和处理器数量的关系。设加速比为 Speedup,系统内必须串行化的程序比重为 F,CPU处理器数量为 N,则有:

根据这个公式,如果CPU处理器数量趋于无穷,那么加速比与系统的串行化率成反比,如果系统中必须有50%的代码串行执行,那么系统的最大加速比为2。

假设有一个程序分为以下步骤执行,每个执行步骤花费100个时间单位,其中,只有步骤 2 和步骤 5 可以进行并行,步骤 1、3、4必须串行,如图1.2所示。在全串行的情况下,系统合计耗时500个时间单位。

图1.2 串行工作流程

若将步骤 2 和步骤 5 并行化,假设在双处理器上,则有如图1.3所示的处理流程。在这种情况下,步骤 2 和步骤 5 的耗时为50个单位。故系统整体耗时为400个时间单位。根据加速比的定义有:

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

或者前文中给出的加速比公式。由于5个步骤中,3个步骤必须串行,因此其串行的比重为3/5=0.6 即F=0.6,且双核处理器个数N为2。带入公式得:

加速比 = 1 /(0.6 + (1-0.6) / 2 = 1.25


图1.3 双核处理器上的并行化

在极端情况下,假设并行处理器个数为无穷大,则有如图1.4所示的处理过程。步骤 2 和步骤 5 的处理时间趋于 0 。即使这样,系统整体耗时依然大于300个时间单位。即加速比的极限为 500 / 300 = 1.67。

图1.4 极端情况下的并行化

使用加速比计算公式,N 趋于无穷大,有 Speedup = 1/F,且 F=0.6,故有 Speedup = 1.67。

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

ps:根据 Amdahl 定律,使用多核CPU对系统进行优化,优化的效果取决于CPU的数量以及系统中的串行化程序比重。CPU数量越多,串行化比重越低,则优化效果越好。仅提高CPU数量而不降低程序的串行化比重,也无法提高系统性能。

时间: 2024-08-02 22:32:31

Java 程序性能优化《第一章》Java性能调优概述 1.1性能概述的相关文章

《Java程序性能优化》学习笔记 JVM调优

第五章 JVM调优5.1 Java虚拟机内存模型 1.JVM虚拟机将其内存数据分为程序计数器.虚拟机栈,本地方法栈,Java堆,和方法去等部分. 2.Java虚拟机栈,在Java 虚拟机规范中,定义了两种异常与占空间相关,即StackOverError和OutOfMemoryError.如果线程在计算过程中,请求的栈深度大于最大可用的栈深度,则抛出SOE,如果Java栈可以动态扩展,而在扩展栈的过程中,没有足够的内存空间来支持栈的扩展,则抛出OutOfMemoryError. 栈的大小直接决定了

《Oracle数据库性能优化方法论和最佳实践》——1.7 Oracle性能优化的神话和误区

1.7 Oracle性能优化的神话和误区 Oracle性能优化工作是Oracle数据库科学最为神秘莫测的领域,自然也就会流传着各种传言和八卦.本书最主要的目的就是真正使Oracle性能优化成为一门严谨的科学,使任何阅读并且理解本书内容的读者可以比较简单地完成Oracle性能优化工作,使自己在其他人面前成为"巫师"或"神秘的对象".1.7.1 艺术和科学 从百度.Google等网站搜索"性能优化艺术",会出现大量的条目,部分Oracle性能优化的图

《Oracle数据库性能优化方法论和最佳实践》——1.4 Oracle性能优化工作的分类

1.4 Oracle性能优化工作的分类 在Oracle上进行性能优化时,不同场景下的优化工作方法和内容有很大的不同.下面从实践角度来展开优化工作的分类.1.4.1 上线优化或从未达到过性能期望的系统优化如果业务系统未进行充分的性能测试就上线,那么有相当一部分会出现性能问题,不会出现性能问题的系统往往建立在有强大硬件的基础之上.这类缺乏性能设计考虑的业务系统部分或全部具有以下特点.开发人员(业务系统)假设资源是无限的,可以任意使用,忘记了任何系统都是在一个资源受限的系统中运行业务.开发人员(业务系

Java 7: 全面教程-第一章节: Java初体验

开发一个Java程序关系到写代码,编译成字节码(bytecode), 和运行字节码.作为一个Java项目开发者将要一直重复做这些事情,所以做这个的时候你要感到舒适是很重要的.而此章节主要目标是让你趁此机会体验Java软件的开发过程. 写代码的关键不仅仅是要让它运做,还要让它方便阅读和维护,此章节介绍了Java 代码的规格.还有,自从聪明的开发者们使用了集成开发环境(Integrated Development Environment,简称IDEs) 使开发变得更简单了,所以此章节的最后一个小节给

Java虚拟机jvm关于内存的设置与调优

JVM内存的设置的原理 默认的java虚拟机的大小比较小,在对大数据进行处理时java就会报错:java.lang.OutOfMemoryError. 设置jvm内存的方法,对于单独的.class,可以用下面的方法对Test运行时的jvm内存进行设置. java -Xms64m -Xmx256m Test -Xms是设置内存初始化的大小 -Xmx是设置最大能够使用内存的大小(最好不要超过物理内存大小) 在weblogic中,可以在startweblogic.cmd中对每个domain虚拟内存的大

CYQ.Data 轻量数据层之路 MDataTable 绑定性能优化之章(十一)

昨天jyk进群后,用Microsoft Application Center Test 对CYQ.Data 框架进行进行了一下压力测试 然后截了几张图上来,只有纯图如下: 1:使用了框架:sql 2000的分页存储过程[临时表分的页]: 2:把存储过程直接换成select语句: 3:他的框架测试结果: 4:这是测试结果了. 以下是说明: 1.DataTable :714次/秒 2.MDataTable:559 次/秒 (简单存储过程) 3.MDataTable:500 次/秒 (完整存储过程)

第一章 Java Web工作原理

一:在本章我们将学到如下的内容 >HTTP协议原理 >服务器端Web编程原理 >Servlet与Web容器 >Java Web应用程序的组成 >Tomcat介绍   一:1.1解析HTTP协议 HTTP:超文本传输协议(HyperText Transfer Protocol) HTTP是一种无状态的协议,意思是指在Web浏览器和Web服务器之间不需要建立持久的连接. HTTP是遵循请求/响应(Request/Response)模型的. HTTP处理流程:     1.1.1建

JAVA数据结构与算法-第一章-综述

面向对象的思想: package com.zzk.cn; class BankAccount { private double balance;//账户余额 public BankAccount(double openingBalance) {//构造函数 balance=openingBalance; } public void deposit(double amount) {//存钱 balance=balance+amount; } public void withdraw(double

Java程序基本优化

1.尽量指定类的final修饰符,因为带有final修饰符的类是不可派生的. 2.尽量重用对象. 3.尽量使用局部变量. 4.不要重复初始化变量. 5.在Java+Oracle的应用系统开发中,Java中内嵌的SQL语句应尽量使用大写,以减轻Oracle解析器解析的负担. 6.在Java编程过程中进行数据库连接.I/O流操作时务必小心,使用完毕后应及时关闭以释放资源. 7.JVM(Java虚拟机)有自身的GC(垃圾回收机制),但并非十分机智.用户对象后手动设置成null. 8.在使用同步机制时,

Java 程序性能优化《第一章》Java性能调优概述 1.2性能调优的层次

Java 程序性能优化<第一章>1.2性能调优的层次 为了提升系统性能,开发人员开始从系统各个角度和层次对系统进行优化.除了最常见的代码优化外,在软件架构上.JVM虚拟机层.数据库以及操作系统层面都可以通过各种手段进行优化,从而在整体上提升系统的性能. 1.2.1 设计调优 设计调优处于所有调优手段的上层,它往往需要在软件开发之前进行.在软件开发之处,软件架构师就应该评估系统可能存在的各种潜在问题,并给出合理的设计方案.由于软件设计和架构对整体质量有决定性的影响,所以,设计调优对系统性能的影响