java性能调优的基础教程

本文涉及的产品
性能测试 PTS,5000VUM额度
简介:   全面的性能调优  编写更好的算法 编写更少的代码 过早优化 过早考虑优化是所有噩梦的根源。应该编写清晰、直接、易读和易理解的代码。 数据库可能是瓶颈 常见的优化 积少成多地改进性能  原则:  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 逃逸分析

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
3天前
|
缓存 算法 Java
Java 实现的局域网管控软件的性能调优
局域网管控软件在企业网络管理中至关重要,但随着网络规模扩大和功能需求增加,其性能可能受影响。文章分析了数据处理效率低下、网络通信延迟和资源占用过高等性能瓶颈,并提出了使用缓存、优化算法、NIO库及合理管理线程池等调优措施,最终通过性能测试验证了优化效果,显著提升了软件性能。
13 1
|
10天前
|
算法 Java 测试技术
java性能调优涉及哪些方面
本文详细探讨了性能调优的各个方面,包括Java编程、多线程、JVM监控、设计模式和数据库调优。文章还介绍了性能调优的标准制定、介入时机、系统性能的影响因素,以及如何衡量和判断系统的性能与负载承受能力。最后,提出了性能调优的具体策略,包括代码、设计、算法优化及参数调整,并讨论了限流、智能化扩容等兜底策略。
java性能调优涉及哪些方面
|
11天前
|
Java 开发工具 Android开发
Kotlin教程笔记(26) -Kotlin 与 Java 共存(一)
Kotlin教程笔记(26) -Kotlin 与 Java 共存(一)
|
2月前
|
Kubernetes Cloud Native Java
云原生之旅:从容器到微服务的演进之路Java 内存管理:垃圾收集器与性能调优
【8月更文挑战第30天】在数字化时代的浪潮中,企业如何乘风破浪?云原生技术提供了一个强有力的桨。本文将带你从容器技术的基石出发,探索微服务架构的奥秘,最终实现在云端自由翱翔的梦想。我们将一起见证代码如何转化为业务的翅膀,让你的应用在云海中高飞。
|
6天前
|
Java 数据库连接 编译器
Kotlin教程笔记(29) -Kotlin 兼容 Java 遇到的最大的“坑”
Kotlin教程笔记(29) -Kotlin 兼容 Java 遇到的最大的“坑”
|
14天前
|
监控 Java Linux
Java 性能调优:调整 GC 线程以获得最佳结果
Java 性能调优:调整 GC 线程以获得最佳结果
52 11
|
9天前
|
Java 编译器 Android开发
Kotlin教程笔记(28) -Kotlin 与 Java 混编
本系列教程笔记详细讲解了Kotlin语法,适合希望深入了解Kotlin的开发者。对于需要快速学习Kotlin的小伙伴,推荐查看“简洁”系列教程。本篇笔记重点介绍了Kotlin与Java混编的技巧,包括代码转换、类调用、ProGuard问题、Android库开发建议以及相互调用时的注意事项。
14 3
|
1月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
308 37
|
11天前
|
Java 编译器 Android开发
Kotlin教程笔记(28) -Kotlin 与 Java 混编
Kotlin教程笔记(28) -Kotlin 与 Java 混编
18 3
|
11天前
|
安全 Java 编译器
Kotlin教程笔记(27) -Kotlin 与 Java 共存(二)
Kotlin教程笔记(27) -Kotlin 与 Java 共存(二)