java性能调优的基础教程-阿里云开发者社区

开发者社区> dasein58> 正文

java性能调优的基础教程

简介:   全面的性能调优   编写更好的算法 编写更少的代码 过早优化 过早考虑优化是所有噩梦的根源。应该编写清晰、直接、易读和易理解的代码。 数据库可能是瓶颈 常见的优化 积少成多地改进性能   原则:   1. 借助性能分析来优化代码,注重性能分析中最耗时的操作   2. 新代码比机器配置更可能引入性能问题,机器配置比JVM或操作系统更容易引入性能问题。
+关注继续查看

  全面的性能调优

  编写更好的算法 编写更少的代码 过早优化 过早考虑优化是所有噩梦的根源。应该编写清晰、直接、易读和易理解的代码。 数据库可能是瓶颈 常见的优化 积少成多地改进性能

  原则:

  1. 借助性能分析来优化代码,注重性能分析中最耗时的操作

  2. 新代码比机器配置更可能引入性能问题,机器配置比JVM或操作系统更容易引入性能问题。

  3. 为应用中最常用的操作编写简单算法

  许多情况下,JVM只占整体性能的一小部分;需要对java所在的环境进行整体系统调优,数据库和其他后台运行系统性能的重要性不亚于JVM。

  性能测试方法

  性能测试原则:

  1. 测试真实应用 : 应该在产品实际使用的环境中进行性能测试

  微基准测试 : 用来测试微小代码单元的性能。

  1. 必须使用被测的结果

  2. 不要包括无关的操作

  3. 必须输入合理的参数 宏基准测试: 测试应用自身,以及它所用到的外部资源 介基准测试: 测量某方面性能的基准测试,但仍然要执行大量代码。

  理解批处理流逝时间、吞吐量和响应时间

  批处理流逝时间: 看它完成任务花了多少时间 吞吐量: 基于一段时间内所能完成的工作量; TPS(每秒事务量)、RPS(每秒请求数)、OPS(每秒操作次数) 响应时间: 从客户端发送请求至收到相应之间的流逝时间。 用统计方法应对性能的变化: 性能测试的结果会随时间而变 尽早频繁测试

  自动化一切 测试一切 在真实系统上运行

  Java性能调优工具箱

  操作系统的工具和分析

  ?

  1系统自带基本监控工具: linux: sarm vmstat, iostat\ prstat window: typeperf

  CPU使用率

  通常CPU使用率可以分为两类:用户态时间(cpu执行应用代码所占时间比)和系统态时间(CPU执行内核代码所占时间比)。

  调优的目的: 在尽可能短的时间内让二手游戏交易平台CPU使用率尽可能地高

  CPU运行队列

  磁盘使用率:

  ?

  12监控目的: 1 与应用本身有关,如果应用做大量磁盘I/O操作,I/O就会成为瓶颈。2 预计应用不会有很高的I/O,有助于监控系统是否在进行内存交换。

  网络使用率

  ?

  1netstat, typeperf

  java监控工具

  jcmd 用来打印java进程所涉及的基本类、线程、vm信息 jconsole jvm活动的图形化视图,包括线程的使用、类的使用和GC活动 jhat 读取内存堆转储 jmap 提供堆转储和其他JVM内存使用的信息 jinfo jvm的系统属性 jstack 转储Java进程的栈信息 jstat 提供GC和类装载活动的信息 jvisualvm jvm监视的GUI工具,

  -XX:+Printflagsfinal 显示调优标志

  性能分析工具

  GlassFish

  NetBeans

  jmc

  JFR开启设置: -XX:+UnlockCommercialFeatures -XX:+flightRecorder

  JIT编译器

  ?

  1JIT(即时)编译器是Java虚拟机的核心

  入门调优: 选择编译器类型

  编译器类型: -server 和 -client ,-d64(64位编译器)

  java -client -XX:+TieredCompilation .jar 指定必须使用server编译器

  中级调优:

  1 调优代码缓存: 代码缓存的大小固定,所以一旦填满,jvm就不能编译更多代码。

  -XX:ReservedCodeCacheSize=N 设置代码缓存大小

  2 编译阈值: 代码执行的频度

  编译是基于两种JVM计数器的: 方法调用计数器和方法中的循环回边计数器。

  -XX:CompileThreshold=N 设置阈值; 阈值=回边计数器+方法调用计数器

  3 检测编译过程

  高级编译器调优

  1 编译线程

  2 A.联

  3 逃逸分析

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9580 0
mysql性能调优的经验整理
1.为查询缓存优化你的查询   例:curdate()、now()、'2015-01-01',前两者都不能利用到数据库的查询缓存,尽量采用常量 2.不使用永久链接 3.innodb_read_io_threads的调优:看innodb状态,如果pending read较大,则调整,调整后观察pending read 4.SQL_NO_CACHE的真正作用是禁止缓存查询结果,但并不意味着cache不作为结果返回给query。
753 0
《循序渐进Linux(第2版) 基础知识 服务器搭建 系统管理 性能调优 虚拟化与集群应用》——4.7 文本编辑工具vi
vi是Linux下标准的文本编辑程序,也是Linux系统命令行下最经常使用的文本文件可视化编辑器,类似于DOS命令edit。那么什么是可视化呢?其实就是让用户在编辑文本文件的时候能够看到它们。这听起来似乎很普通,但是在命令行的字符界面下,可视化编辑确实起了很大的作用。
1823 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13291 0
改善Java性能的基本建议
改善Java性能的基本建议 Document #: 2811085C29001 Body: [标题]下面是在AIX上改善 Java 性能的基本建议· 当进行过多的字符串操作以避免不必要地创建那些最终必须经历垃圾收集的对象时,可使用 StringBuffer 功能而不是字符串并置。
595 0
.NET性能调优之三:YSlow相关规则的调优工具和方法
.NET性能调优系列文章 系列文章索引 .NET性能调优之一:ANTS Performance Profiler的使用 .NET性能调优之二:使用Visual Studio进行代码度量 .NET性能调优之三:YSlow相关规则的调优工具和方法 1.YSlow简介 在这篇文章里来谈谈web前端的相关优化,主要遵从YSlow规则,具体的规则意义在YSlow的23条规则描述里已经描述的很清楚,不再赘述,那么这里主要来探讨下如何针对部分规则进行相关调优。
1129 0
+关注
765
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载