当前位置: 首页 > java >正文

一、内存调优

一、内存调优

什么是内存泄漏
监控Java内存的常用工具
内存泄露的常见场景
内存泄露的解决方案

内存泄露与内存溢出的区别
内存泄露:在Java中如果不再使用一个对象,但是该对象依然在GC ROOT的引用链上,这个对象就不会被垃圾回收器回收,这种情况称之为内存泄露。
在这里插入图片描述

少量的内存泄露可以容忍,但是如果发生持续的内存泄露,就像滚雪球,雪球约滚约大,不管有多大的内存迟早会被消耗完,最终导致的结果就是内存溢出。但是产生内存溢出并不是只有内存泄露这一种原因。
在这里插入图片描述
内存泄露的常见场景
1、内存泄露导致溢出的常见场景是大型的Java后端应用中,在处理用户的请求之后,没有及时将用户的数据删除。随着用户请求数量越来越多,内存泄露的对象占满了对内存最终导致内存溢出。
这种产生的内存溢出会直接导致用户请求无法处理,影响用户的正常使用。重启可以恢复应用使用,但是在运行一段时间之后依然会出现内存溢出。
2、第二种常见场景是分布式任务调度系统如Elastic-job、Quartz等进行任务调度时,被调度的Java应用在调度任务结束中,如果出现了内存泄露,最终导致多次调度之后内存溢出。
这种产生的内存溢出会导致应用执行下次的调度任务执行。同样重启可以恢复应用使用,但是在调度执行一段时间后依然会出现内存溢出。
解决内存溢出的方法
解决内存溢出的步骤总共分为四个步骤,其中前两个步骤是最核心的。
在这里插入图片描述
发现问题-Top命令
top命令,实时查看系统的资源,比如执行时的进程、线程和系统参数等信息。

load average 分别代表过去 1分钟 5分钟 15分钟的系统负载,什么是系统的负载,多核cpu,百分之二, 百分之十 、百分之六
进程使用的内存为RES(常驻内存)-SHR(共享内存)
在这里插入图片描述

优点:操作简单、无额外的软件安装
缺点:只能查看最基础的进程信息,无法查看到每个部分的内存占用(堆、方法区、堆外)

http://www.xdnf.cn/news/7241.html

相关文章:

  • elasticsearch之记录es7.17升级8.17 springboot2.7.0 程序改造坑
  • Spring Boot与Kafka集成实践:从入门到实战
  • LLM最后怎么输出值 解码语言模型:从权重到概率的奥秘
  • 理解硬链接和软链接:原理与实践
  • 教学网站1:《软件工程》精品课程教学网站的设计与实现(摘要和目录)
  • PLC双人舞:profinet转ethernet ip网关奏响施耐德与AB的协奏曲
  • MYSQL笔记
  • virtual下Ubuntu24.04版本上配置网络与外网和宿主机之间互通
  • iOS 蓝牙开发中的 BT 与 BLE
  • 2025毕业论文与答辩资料精选汇总
  • 32、跨平台咒语—— React Native初探
  • 已知6、7、8月月平均气温和标准差,求夏季季平均温度与标准差
  • 算法题(150):拼数
  • FreeMarker
  • 【实战】GPT-SoVITS+内网穿透:3分钟搭建可公网访问的语音克隆系统
  • 【python基础知识】Day30 模块和库的导入
  • 数据结构实验10.1:内部排序的基本运算
  • 【android bluetooth 协议分析 01】【HCI 层介绍 9】【ReadLocalSupportedCommands命令介绍】
  • 没有保安工作经验,如何备考初级保安员证的实操考试?
  • 数据分析入门指南:从历史到实践
  • 物联网之使用Vertx实现HTTP/WebSocket最佳实践
  • 精益数据分析(69/126):最小可行化产品(MVP)的设计、验证与数据驱动迭代
  • Android framework 问题记录
  • Ubuntu开机自启服务
  • 【数据仓库面试题合集③】实时数仓建模思路与实践详解
  • InternLM 论文分类微调实践(XTuner 版)
  • Java设计模式之外观模式:从入门到精通(保姆级教程)
  • 基于Elasticsearch的搜索引擎简介
  • 【Android】一键创建Keystore + Keystore 参数说明 + 查询SHA256(JDK Keytool Keystore)
  • 【神经网络与深度学习】GAN 生成对抗训练模型在实际训练中很容易判别器收敛,生成器发散