JVM 性能优化思路

news2025/1/22 15:52:01

点击下方关注我,然后右上角点击...“设为星标”,就能第一时间收到更新推送啦~~~

一般在系统出现问题的时候,我们会考虑对 JVM 进行性能优化。优化思路就是根据问题的情况,结合工具进行问题排查,针对排查出来的可能问题找到对应的解决方案。

1

JVM 优化思路

51c8121e78367a8e5cdfd5efa82f076c.png

1、系统中可能会出现的问题

1、OOM:OOM是指Java虚拟机在启动或运行过程中,无法申请到足够的内存空间,导致抛出java.lang.OutOfMemoryError。

OOM产生的原因可能有以下几点:

(1)代码中存在大对象分配。

(2)内存泄露,导致在多次GC之后,还是无法找到一块足够大的内存容纳当前对象。

(3)永久代/元空间设置的过小。

(4)应用长时间运行,没有重启,运行期间生成了大量的类。

2、死锁:死锁是指两个或两个以上的进程或线程,在执行过程中,由于竞争资源而造成的一种阻塞的现象,若无外力作用,它们都将无法继续执行。

3、CPU 飙升:CPU飙升是指程序运行时CPU占用率过高。

CPU飙升的可能原因如下:

(1)系统负载高:负载高表示有很多程序等待调度运行,它会导致上下文切换频繁。

(2)大量并发的I/O操作。

(3)多线程抢占系统资源。

4、线程池不够用:线程池不够用指的是当前线程数小于核心线程数,但已提交的任务个数大于当前线程数,这时线程池中的线程无法满足任务的需求,需要创建新的线程来执行任务。

5、GC 次数频繁:GC次数频繁是指程序运行时Full GC的次数超过了可接受的正常水平。

2、问题排查的手段

(1)用 jmap 命令 dump 出堆文件,利用 MAT 工具分析

(2)用 jstack 命令查看线程堆栈信息

(3)用 top 命令查看占用 CPU 高的进程,结合 jps,jinfo,jstat,jmap 等命令分析原因

(4)用 jvisualvm、jconsole、arthas 等工具查看 JVM 状态

(5)开启 GC 日志打印,结合 GCViewer 分析 GC 日志,查看 GC 执行情况

3、常用的解决方案

(1)适当增加堆内存大小

(2)选择合适的垃圾收集器

(3)代码中及时释放资源

(4)合理设置线程池的参数

(5)集群部署增加负载能力

(6)利用 MQ 进行异步削峰

(7)综合利用本地缓存、Redis 缓存减少数据库压力

2

常用问题分析思路

dd31e0f8de95697f9fe4575ebcdc523f.png

1、OOM 问题

导出 dump 文件,然后用 MAT 或者其他工具分析 dump 文件,分析为什么内存使用高了,我们可以适当增加堆内存的空间,也可以适当的减少并发数,增加消息队列来解决等。

2、CPU 飙升问题

使用 top 命令找到 CPU 使用率高的进程,我们可以通过 jstack 查看线程情况,通过 jinfo 命令查看 JVM 参数,通过 jmap 命令查看堆内存,如果是业务代码问题(死锁、资源没释放),那么可以修改代码;如果是用户并发太高,那么可以增加集群数量来减轻服务器压力;如果是没有异步处理,那么可以使用消息队列等,如果是垃圾回收的线程一直占用 CPU,那么可以对 GC 进行优化。

3、GC 频繁问题

开启 GC 日志打印,使用 GCViewer 工具分析 GC 日志,查看 GC 执行情况,如果是堆内存空间的问题,那么我们可以适当增加堆内存的空间,比如调高新生代空间;如果是垃圾收集器设置的不合适,我们可以选择合适的垃圾收集器,比如大内存空间可以选择 G1;如果使用 G1 收集器,暂停时间设置的太小,我们可以把暂停时间适当调大一点,初始堆内存设置的太小,我们可以适当调大一点初始堆内存设置等。

后面将为大家介绍常见的 JVM 面试题分析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/856671.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

06 - Stream如何提高遍历集合效率?

前面我们讲过 List 集合类,那我想你一定也知道集合的顶端接口 Collection。 在 Java8 中,Collection 新增了两个流方法,分别是 Stream() 和 parallelStream()。 1、什么是 Stream? 现在很多大数据量系统中都存在分表分库的情况…

安防视频监控平台EasyNVR页面无法上传授权文件,该如何进行授权?

TSINGSEE青犀视频安防监控平台EasyNVR可支持设备通过RTSP/Onvif协议接入,并能对接入的视频流进行处理与多端分发,包括RTSP、RTMP、HTTP-FLV、WS-FLV、HLS、WebRTC等多种格式。在智慧安防等视频监控场景中,EasyNVR可提供视频实时监控直播、云端…

LeetCode 1289. 下降路径最小和 II:通俗易懂地讲解O(n^2) + O(1)的做法

【LetMeFly】1289.下降路径最小和 II:通俗易懂地讲解O(n^2) O(1)的做法 力扣题目链接:https://leetcode.cn/problems/minimum-falling-path-sum-ii/ 给你一个 n x n 整数矩阵 arr ,请你返回 非零偏移下降路径 数字和的最小值。 非零偏移下…

【力扣每日一题】2023.8.10 下降路径最小和Ⅱ

目录 题目: 示例: 分析: 代码: 题目: 示例: 分析: 题目给我们一个数组,让我们模拟从上面第一层走到下面的最后一层,下降路径需要加上经过的格子的值,每层…

vue使用ElementUI

1.安装 npm i element-ui -S 2.引入 2.1完整引入 import Vue from vue; import ElementUI from element-ui; import element-ui/lib/theme-chalk/index.css; import App from ./App.vue;Vue.use(ElementUI); 2.2按需引入 说明:为了输入时候有提示,建…

【雕爷学编程】Arduino动手做(03)---RCWL-0516微波雷达传感器模块2

37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&#x…

S7-1500系列PLC读取V90伺服驱动器电流扭矩等参数的具体方法示例(2种)

S7-1500系列PLC读取V90伺服驱动器电流扭矩等参数的具体方法示例(2种) 示例1: 当V90PN配置为EPOS控制模式下的标准报文111时,报文中在接受与发送方向均包含一个可供用户自定义的保留字(PZD12)。 在这种条件下,可以通过修改参数P29151(用户自定义PZD发送字)来定义传输方…

YOLOV5改进:更换为MPDIOU,实现有效涨点

1.该文章属于YOLOV5/YOLOV7/YOLOV8改进专栏,包含大量的改进方式,主要以2023年的最新文章和2022年的文章提出改进方式。 2.提供更加详细的改进方法,如将注意力机制添加到网络的不同位置,便于做实验,也可以当做论文的创新点。 2.涨点效果:更换为MPDIOU,实现有效涨点! 目录…

【雕爷学编程】Arduino动手做(201)---DFRobot 行空板03

37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&#x…

三种常见的平滑滤波方法

一、概述 平滑滤波,顾名思义就是对信号进行处理使之整体显得更加平滑,降低噪声影响,提高信号质量,它常见于数学信号处理和图像处理,一般意义上的数字信号多体现于一维数据,图像信号多体现于二维数据。   …

基于Java的体育网站的设计与实现(论文+源码)_kaic

基于Java的体育网站的设计与实现 摘 要:在网络应用的迅速发展与科技的不断进步的现代环境下,人们生活节奏越来越快,娱乐方式也多种多样,各种软件应用,各种娱乐,购物网站已经成为必不可少的伴随品&#xff…

Jenkins+Docker+SpringCloud微服务持续集成项目优化和微服务集群

JenkinsDockerSpringCloud微服务持续集成项目优化和微服务集群 JenkinsDockerSpringCloud部署方案优化JenkinsDockerSpringCloud集群部署流程说明修改所有微服务配置 设计Jenkins集群项目的构建参数编写多选项遍历脚本多项目提交进行代码审查多个项目打包及构建上传镜像把Eurek…

一种简单高效的IMU姿态解算方法

这里给出一种简单高效的IMU姿态解算方法,本方法的特点就是思路非常的简单,并且效果也还可以,地面机器人这类运动想对不那么剧烈的应用应该是能应付的,但是震动较大的无人机、足式机器人等应用是否能应用还有待试验。 代码如下&am…

【Leetcode】(自食用)LRU算法(哈希链表法)

step by step. 题目: 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中,则返回关键…

【深度学习注意力机制系列】—— CBAM注意力机制(附pytorch实现)

CBAM(Convolutional Block Attention Module)是一种用于增强卷积神经网络(CNN)性能的注意力机制模块。它由Sanghyun Woo等人在2018年的论文[1807.06521] CBAM: Convolutional Block Attention Module (arxiv.org)中提出。CBAM的主…

实现静态资源访问的几种方法

什么是静态资源? 静态资源是指在服务器端存储的不会变化的文件,如HTML、CSS、JavaScript、图片、音频、视频等文件。这些文件一般不包含动态内容,每次请求时返回的内容都是固定的。 为什么要使用静态资源? 提升网站性能&#xf…

gitblit-使用

1.登入GitBlit服务器 默认用户和密码: admin/admin 2.创建一个新的版本库 点击图中的“版本库”,然后点击图中“创建版本库” 填写名称和描述,注意名称最后一定要加 .git选择限制查看、克隆和推送勾选“加入README”和“加入.gitignore文件”在图中的1处…

kafka-2.12使用记录

kafka-2.12使用记录 安装kafka 2.12版本 下载安装包 根据你的系统下载rpm /deb /zip包等等, 这里我使用的是rpm包 安装命令 rpm -ivh kafka-2.12-1.nfs.x86_64.rpm启动内置Zookeeper 以下命令要写在同一行上 /opt/kafka-2.12/bin/zookeeper-server-start.sh /opt/kafka-2…

5.3.7.自动创建字符设备驱动的设备文件 class_create device_create

5.3.7.自动创建字符设备驱动的设备文件 5.3.7.1、问题描述: (1)整体流程回顾 (2)使用mknod创建设备文件的缺点 (3)能否自动生成和删除设备文件 5.3.7.2、解决方案:udev是PC机(嵌入式中用的是mdev) (1)什么是udev?应用层…

C语言笔记6

关于microsoft visual 的学习笔记 CtrlF5就是启动编译程序 先CtrlA进行全选&#xff0c;然后AitF8就自动的调节代码的格式 #include <stdio.h> #include <stdlib.h> int main() {//system启动程序(在一个程序中启动另外一个程序)//如果程序环境变量中找不到程序&am…