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

一、内存调优

一、内存调优

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

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

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

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

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

相关文章:

  • 低功耗:XILINX FPGA如何优化功耗?
  • 人工智能(AI)与BIM:建筑业创新实践的深度融合
  • 供应商管理有哪些风险点?
  • C++11特性
  • HTML向四周扩散背景
  • DriveGenVLM:基于视觉-语言模型的自动驾驶真实世界视频生成
  • C#中的ThreadStart委托
  • 代理IP高可用性与稳定性方案:负载均衡、节点健康监测与智能切换策略
  • LLaMA-Factory:了解webUI参数
  • 【hive】hive内存dump导出hprof文件
  • 虚幻引擎5-Unreal Engine笔记之什么时候新建GameMode,什么时候新建关卡?
  • solidity智能合约-知识点
  • 开源音视频转文字工具:基于 Vosk 和 Whisper 的多语言语音识别项目
  • B/S架构和C/S架构的介绍与分析
  • 如何在LVGL之外的线程更新UI内容
  • 从纸质契约到智能契约:AI如何改写信任规则与商业效率?​——从智能合约到监管科技,一场颠覆传统商业逻辑的技术革命
  • Unreal 从入门到精通之SceneCaptureComponent2D实现UI层3D物体360°预览
  • 学习VS2022离线安装包的下载方法
  • STC-ISP烧录过程中一直显示“正在检测单片机”的解决办法
  • WebSphere Application Server(WAS)8.5.5教程第五讲
  • 中科院合肥物质院迎来新一届领导班子:刘建国继续担任院长
  • 浦江潮涌征帆劲,上海以高质量发展服务全国发展大局
  • 经济日报:人工智能开启太空经济新格局
  • 广西鹿寨一水文站“倒刺扶手”存安全隐患,官方通报处理情况
  • 精品消费“精”在哪?多在体验上下功夫
  • 国家卫生健康委通报关于肖某引发舆情事件调查处置进展情况