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 逃逸分析

目录
相关文章
|
4月前
|
Java 关系型数据库 数据库
Java 项目实战教程从基础到进阶实战案例分析详解
本文介绍了多个Java项目实战案例,涵盖企业级管理系统、电商平台、在线书店及新手小项目,结合Spring Boot、Spring Cloud、MyBatis等主流技术,通过实际应用场景帮助开发者掌握Java项目开发的核心技能,适合从基础到进阶的学习与实践。
588 4
|
3月前
|
安全 Java
Java之泛型使用教程
Java之泛型使用教程
286 10
|
2月前
|
Oracle Java 关系型数据库
Java 简单教程
Java是跨平台、面向对象的编程语言,广泛用于企业开发、Android应用等。本教程涵盖环境搭建、基础语法、流程控制、面向对象、集合与异常处理,助你快速入门并编写简单程序,为进一步深入学习打下坚实基础。
345 0
|
10月前
|
JavaScript NoSQL Java
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
500 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
|
5月前
|
缓存 安全 Java
Java 并发新特性实战教程之核心特性详解与项目实战
本教程深入解析Java 8至Java 19并发编程新特性,涵盖CompletableFuture异步编程、StampedLock读写锁、Flow API响应式流、VarHandle内存访问及结构化并发等核心技术。结合电商订单处理、缓存系统、实时数据流、高性能计数器与用户资料聚合等实战案例,帮助开发者高效构建高并发、低延迟、易维护的Java应用。适合中高级Java开发者提升并发编程能力。
170 0
|
6月前
|
Oracle Java 关系型数据库
java 编程基础入门级超级完整版教程详解
这份文档是针对Java编程入门学习者的超级完整版教程,涵盖了从环境搭建到实际项目应用的全方位内容。首先介绍了Java的基本概念与开发环境配置方法,随后深入讲解了基础语法、控制流程、面向对象编程的核心思想,并配以具体代码示例。接着探讨了常用类库与API的应用,如字符串操作、集合框架及文件处理等。最后通过一个学生成绩管理系统的实例,帮助读者将理论知识应用于实践。此外,还提供了进阶学习建议,引导学员逐步掌握更复杂的Java技术。适合初学者系统性学习Java编程。资源地址:[点击访问](https://pan.quark.cn/s/14fcf913bae6)。
803 2
|
11月前
|
消息中间件 Java 数据库
自研Java框架 Sunrays-Framework使用教程「博客之星」
### Sunrays-Framework:助力高效开发的Java微服务框架 **Sunrays-Framework** 是一款基于 Spring Boot 构建的高效微服务开发框架,深度融合了 Spring Cloud 生态中的核心技术组件。它旨在简化数据访问、缓存管理、消息队列、文件存储等常见开发任务,帮助开发者快速构建高质量的企业级应用。 #### 核心功能 - **MyBatis-Plus**:简化数据访问层开发,提供强大的 CRUD 操作和分页功能。 - **Redis**:实现高性能缓存和分布式锁,提升系统响应速度。 - **RabbitMQ**:可靠的消息队列支持,适用于异步
自研Java框架 Sunrays-Framework使用教程「博客之星」
|
监控 Java 编译器
Java虚拟机调优指南####
本文深入探讨了Java虚拟机(JVM)调优的精髓,从内存管理、垃圾回收到性能监控等多个维度出发,为开发者提供了一系列实用的调优策略。通过优化配置与参数调整,旨在帮助读者提升Java应用的运行效率和稳定性,确保其在高并发、大数据量场景下依然能够保持高效运作。 ####
308 58
|
12月前
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
11322 5
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
11月前
|
Java 数据库连接 数据处理
探究Java异常处理【保姆级教程】
Java 异常处理是确保程序稳健运行的关键机制。它通过捕获和处理运行时错误,避免程序崩溃。Java 的异常体系以 `Throwable` 为基础,分为 `Error` 和 `Exception`。前者表示严重错误,后者可细分为受检和非受检异常。常见的异常处理方式包括 `try-catch-finally`、`throws` 和 `throw` 关键字。此外,还可以自定义异常类以满足特定需求。最佳实践包括捕获具体异常、合理使用 `finally` 块和谨慎抛出异常。掌握这些技巧能显著提升程序的健壮性和可靠性。
200 4