性能啊!性能!

之所以想写写性能调优,也是有感于我们的项目,我们採用一些手段使得系统性能上升了一个台阶,总是须要把这点经验沉淀一下。随着工作的深入,关于系统性能的事肯定还有非常多,也算是通过这个系列文章做做笔记。优化可能包含应用级别的优化,也可能包含代码级别的优化。

“要进行优化,先得找到性能瓶颈!”


忘记是从哪里看到了这句话,但总算切中要害。

但在找性能瓶颈之前,我们总要先对系统性能有一个概念。

怎样在不购买新硬件的条件下完毕很多其它的工作?何时才真正须要加入硬件(很多其它的内存,更快的磁盘、 CPU以及网络接口)?有时仅仅需消除一些简单的瓶颈就可以解决很多性能问题——可是要实现它,你必须充分了解自己的计算机和网络,从而找到真正的瓶颈所在。在预算短缺的今天,理解怎样优化系统性能比以往不论什么时候都重要。一味地投资并非可以让人们接受的办法——而且也不一定生效
                                                                                                                                       -------《系统性能优化》

再看两篇文章吧

http://www.kuqin.com/system-analysis/20120116/317410.html



看了上面的陈述,相信你已经有所感触,说得直白一点,系统性能就是在尽可能降低投资的情况下,解决以下两个事:

  1. Throughput ,吞吐量。也就是每秒钟能够处理的请求数,任务数。
  2. Response time, 响应时间。也就是系统在处理一个请求或一个任务时的响应时间。

我们要做优化,就是为了让吞吐量更大,让响应时间更短,在二者之间达到平衡,满足我们的业务要求。

所以,我们要发现性能瓶颈,事实上就是找到影响吞吐量和响应时间的地方。


怎么找?

使用工具!

这里提到了

十个免费的Web压力測试工具


工具还有非常多,上面10个,我没有亲自用过,只是,我倒是用过一个測试java web项目性能的工具:javamelody

JavaMelody可以在QA和实际运行生产环境监測Java或Java EE应用程序server。并以图表的形式显示:Java内存和Java CPU使用情况,用户Session数量,JDBC连接数,和http请求、sql请求、jsp页面与业务接口方法(EJB3、Spring、Guice)的运行数量,平均运行时间,错误百分比等。图表可以按天,周,月,年或自己定义时间段查看。


截张图给大家看看


这仅仅是一部分图标,它提供的信息要远比这丰富。

工具和方法论说多了无益,下篇文章给大家来点猛料。

发现瓶颈,怎么办?别急着去找程序的麻烦,先去操作系统,操作系统的报告。看看操作系统的CPU利用率,看看内存使用率,看看操作系统的IO,还有网络的IO,网络链接数,等等。通过了解操作系统的性能,我们才知道性能的问题,比方:带宽不够,内存不够,TCP缓冲区不够,等等,非常多时候,不须要调整程序的,仅仅须要调整一下硬件或操作系统的配置就能够了。说这些是为了提醒你,不要急着去改动你的代码。

假设到了非要动代码的地步,瓶颈这东西也能够依据2:8原则来说,20%的代码耗了你80%的性能,找到那20%的代码,你就能够优化那80%的性能。所以,紧紧锁定那不到20%的代码。

兴许文章,我会列举一些项目中性能调优的经验,供大家參考,也欢迎补充。





《java系统性能调优》--1.发现瓶颈的更多相关文章

  1. Android系统性能调优工具介绍

    http://blog.csdn.net/innost/article/details/9008691 经作者授权,发表Tieto某青年牛的一篇<程序员>大作. Android系统性能调优 ...

  2. linux系统性能调优第一步——性能分析(vmstat)

    linux系统性能调优第一步--性能分析(vmstat) 分类: LINUX 性能调优的第一步是性能分析,下面从性能分析着手进行一些介绍,尤其对linux性能分析工具vmstat的用法和实践进行详细介 ...

  3. Java性能调优笔记

    Java性能调优笔记 调优步骤:衡量系统现状.设定调优目标.寻找性能瓶颈.性能调优.衡量是否到达目标(如果未到达目标,需重新寻找性能瓶颈).性能调优结束. 寻找性能瓶颈 性能瓶颈的表象:资源消耗过多. ...

  4. Java性能调优:利用JMC分析性能

    Java性能调优作为大型分布式系统提供高性能服务的必修课,其重要性不言而喻. 好的分析工具能起到事半功倍的效果,利用分析利器JMC.JFR,可以实现性能问题的准确定位. 本文主要阐述如何利用JMC分析 ...

  5. 11个简单实用技巧--Java性能调优

    多数开发人员认为性能优化是个比较复杂的问题,需要大量的经验和知识.是的,这并不没有错.诚然,优化应用程序以获得最好的性能并不是一件容易的事情,但这并不意味着你在没有获得这些经验和知识之前就不能做任何事 ...

  6. Java性能调优概述

    目录 Java性能调优概述 性能优化有风险和弊端,性能调优必须有明确的目标,不要为了调优而调优!!!盲目调优,风险远大于收益!!! 程序性能的主要表现点 执行速度:程序的反映是否迅速,响应时间是否足够 ...

  7. Java性能调优的11个实用技巧

    译文出处: ITeye    原文出处:dzone 大多数开发人员认为性能优化是个比较复杂的问题,需要大量的经验和知识.是的,这并不没有错.诚然,优化应用程序以获得最好的性能并不是一件容易的事情,但这 ...

  8. Perf Event :Linux下的系统性能调优工具

    Perf Event :Linux下的系统性能调优工具 2011-05-27 10:35 刘 明 IBMDW 字号:T | T Perf Event 是一款随 Linux 内核代码一同发布和维护的性能 ...

  9. Java 性能调优的 11 个实用技巧

    大多数开发人员认为性能优化是个比较复杂的问题,需要大量的经验和知识.是的,这并不没有错.诚然,优化应用程序以获得最好的性能并不是一件容易的事情,但这并不意味着你在没有获得这些经验和知识之前就不能做任何 ...

随机推荐

  1. Codeforces 549H. Degenerate Matrix 二分

    二分绝对值,推断是否存在对应的矩阵 H. Degenerate Matrix time limit per test 1 second memory limit per test 256 megaby ...

  2. ORACLE 实验一

    实验一:数据定义 实验学时:4学时 实验类型:综合型 实验要求:必修 一.实验目的 1.熟悉Oracle的client配置: 2.掌握SQL Plus的使用: 3.掌握SQL模式定义语句,定义相关的表 ...

  3. Codeforces 442B Andrey and Problem(贪婪)

    题目链接:Codeforces 442B Andrey and Problem 题目大意:Andrey有一个问题,想要朋友们为自己出一道题,如今他有n个朋友.每一个朋友想出题目的概率为pi,可是他能够 ...

  4. Android学习小Demo(19)利用Loader来实时接收短信

    之前写过一篇文章<Android学习小Demo(13)Android中关于ContentObserver的使用>,在里面利用ContentOberver去监測短信URI内容的变化.我们先来 ...

  5. SQL Server 连接问题-TCP/IP

    原文:SQL Server 连接问题-TCP/IP 出自:http://blogs.msdn.com/b/apgcdsd/archive/2012/02/24/ms-sql-server-tcp-ip ...

  6. android file.createnewfile ioexception

    近期在写项目的时候,文件有时候能创建成功有时候直接io异常,真是太扯淡.找了许久,最终找到原因 android 中创建文件,文件的名字中不能包括冒号啊这种特殊字符, 仅仅要你感觉有点特殊的字符最好都不 ...

  7. ANDROID嵌入式应用Unity3D视图(画廊3D模型)

    转载请注明来自大型玉米的博客文章(http://blog.csdn.net/a396901990),谢谢支持! 效果展示:   watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  8. atitit.为什么技术的选择方法java超过.net有前途

    atitit.为什么技术的选择方法java超过.net有前途 #----有没有法律依据不同的铜需求... 通常有开发效率,需要在稳定性.. 笔者 老哇爪 Attilax 艾龙,  EMAIL:1466 ...

  9. ASP.NET Identity 身份验证和基于角色的授权

    ASP.NET Identity 身份验证和基于角色的授权 阅读目录 探索身份验证与授权 使用ASP.NET Identity 身份验证 使用角色进行授权 初始化数据,Seeding 数据库 小结 在 ...

  10. Linux内核分析(二)----内核模块简介|简单内核模块实现

    原文:Linux内核分析(二)----内核模块简介|简单内核模块实现 Linux内核分析(二) 昨天我们开始了内核的分析,网上有很多人是用用源码直接分析,这样造成的问题是,大家觉得很枯燥很难理解,从某 ...