1.1 性能概述



第1章  Java性能调优概述

本章对性能优化技术进行整体性的介绍,让读者了解性能的概念和性能优化的基本思路与方法。掌握这些内容,有助于读者对性能问题进行系统性的分析。

本章涉及的主要知识点有:

评价性能的主要指标;

木桶原理的概念及其在性能优化中的应用;

Amdahl定律的含义;

性能调优的层次;

系统优化的一般步骤和注意事项。

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就是系统的性能瓶颈。

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

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 软件需求与开发计划 1.1 系统概述与系统开发目标 本系统是一个商品管理系统,旨在帮助商家有效管理商品信息,包括商品的基本信息、库存、销售情况等,提高商品销售和管理效率,降低管理成本。 1.2 系统功能需求分析 系统主要包括以下功能: - 商品信息管理:包括商品基本信息、库存、销售情况等的管理。 - 订单管理:包括订单的查询、修改、删除等。 - 用户管理:包括用户的注册、登录、密码修改等。 - 数据统计:包括商品销售额、库存情况、订单量等的统计分析。 1.3 系统性能需求分析 系统性能要求如下: - 响应速度:系统需要快速响应用户请求,保证用户体验。 - 并发性能:系统需要支持多个用户同时使用,保证并发性能。 - 数据安全性:系统需要保证数据的安全性和完整性,防止数据泄露和篡改。 1.4 系统运行环境与外部接口分析 系统运行环境如下: - 操作系统:Windows、Linux等。 - 数据库:MySQL、Oracle等。 - Web服务器:Tomcat、Apache等。 - 浏览器:IE、Chrome、Firefox等。 系统需要与第三方支付系统接口,实现在线支付功能。 1.5 项目开发计划 项目开发计划如下: - 需求分析阶段:完成系统需求分析,确定系统功能和性能需求。 - 设计阶段:完成系统总体(概要)设计、UI设计、数据库设计、详细设计。 - 编码阶段:完成系统编码和单元测试。 - 测试阶段:完成系统集成测试、系统测试和验收测试。 - 上线运行阶段:完成系统部署、安装及数据初始化,正式上线运行。 2. 系统设计说明 2.1 系统总体(概要)设计 系统总体设计如下: - 前端采用Web技术实现,后端采用Java语言开发。 - 前端通过Ajax技术与后端进行交互,实现数据的异步加载和提交。 - 后端采用Spring MVC框架实现业务逻辑处理和数据持久化。 - 数据库采用MySQL数据库,通过JDBC技术实现数据访问。 2.2系统UI设计(Web前端) 系统UI设计如下: - 登录页面:实现用户登录功能,包括用户名和密码输入、验证码校验等。 - 商品管理页面:显示所有商品信息,支持商品的添加、修改、删除操作。 - 订单管理页面:显示所有订单信息,支持订单的查询、修改、删除操作。 - 用户管理页面:显示所有用户信息,支持用户的注册、登录、密码修改等操作。 - 数据统计页面:实现对商品销售额、库存情况、订单量等数据的统计分析。 2.3 系统数据库设计 系统数据库设计如下: - 商品信息表:包括商品ID、商品名称、商品类别、商品描述、商品价格、库存等字段。 - 订单信息表:包括订单ID、订单时间、订单金额、订单状态等字段。 - 用户信息表:包括用户ID、用户名、密码、用户类型等字段。 2.4 系统功能详细设计 系统功能详细设计如下: - 商品信息管理: - 商品信息添加:前端页面输入商品信息,后端将商品信息插入数据库。 - 商品信息修改:前端页面修改商品信息,后端将商品信息更新到数据库。 - 商品信息删除:前端页面选择要删除的商品,后端将商品信息从数据库中删除。 - 商品信息查询:前端页面输入查询条件,后端从数据库中查询符合条件的商品信息。 - 订单管理: - 订单信息查询:前端页面输入查询条件,后端从数据库中查询符合条件的订单信息。 - 订单信息修改:前端页面修改订单信息,后端将订单信息更新到数据库。 - 订单信息删除:前端页面选择要删除的订单,后端将订单信息从数据库中删除。 - 用户管理: - 用户注册:前端页面输入注册信息,后端将用户信息插入数据库。 - 用户登录:前端页面输入登录信息,后端验证用户身份是否正确。 - 密码修改:前端页面输入旧密码和新密码,后端将用户密码更新到数据库。 - 数据统计: - 商品销售额统计:查询订单表,统计每个商品的销售额。 - 库存情况统计:查询商品表,统计每个商品的库存情况。 - 订单量统计:查询订单表,统计每个时间段的订单量。 3. 系统实现与系统使用说明 3.1 系统部署、安装及数据初始化 系统部署、安装及数据初始化如下: - 部署:将系统部署在Web服务器上。 - 安装:安装数据库和Web服务器。 - 数据初始化:创建数据库表,插入初始数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值