JVM和GC监控技术

news2025/1/11 13:59:06

一、监控技术简介

  1. JVM是什么?
  2. 项目里面有JVM吗?
  3. JVM跟Tomcat有什么关系?
  4. 为什么需要去分析JVM?
1. JVM(全称:Java Virtual Machine),Java虚拟机

是Java程序运行的环境,它是一个虚构的计算机,相当于电脑安装系统一样,可以运行应用程序,很多应用使用java语言开发,java最大特点跨平台(windows、linux),真正的java程序在java虚拟机上运行

在这里插入图片描述
如上图:JDK、JRE、JVM:JDK(开发工具包)包含了JRE(运行环境),运行时类、库,JRE包含了JVM(java虚拟机)

2. 项目里面有JVM吗?

让tomcat运行起来,就需要有JRE,而JRE自带了JVM

3. JVM跟Tomcat有什么关系?
  • 一个tomcat是一个java进程,其中有很多线程(与有多少个app无关)
  • 一个tomcat启动一个JVM,其中可以有很多APP
  • 一个tomcat中部署的多个APP,虽然同处一个JVM,但是由于无法相互调用,可以认为是分布式的
4. 为什么需要去分析JVM?

JVM对于tomcat来说就相当于运行系统

二、JVM的生命周期

  1. JVM实例诞生:
    当启动一个java程序时,一个JVM实例就诞生了,任何一个拥有public void main(String[] args)函数的class都可以作为JVM实例运行的起点
  2. JVM实例运行:
    main()作为该程序初始线程的起点,任何其他线程均有该线程启动,JVM内部有两种线程,守护线程和非守护线程,main()属于非守护线程,守护线程通常由JVM自己使用,java程序也可以标明自己创建的线程是守护线程
  3. JVM实例的消亡:
    当程序中的所有非守护线程都终止时,JVM才退出

三、JVM的GC机制

  1. GC概述

    • garbage collection是进程查看堆内存,分辨哪些对象还在被使用中,哪些对象已经不再使用,并删除不再使用的对象的过程
      • 被使用:指程序中的某些部分仍然由对对象的引用
      • 不再被使用:就是指没有任何部分持有该对象的引用,对于不再被使用的对象,其消耗的内存可以被回收重用,(没有保护(守护线程)就回收掉,释放掉更多的内存给需要的线程使用)
  2. GC分代回收机制:

    • GC分代回收机制(java8 HotSpot分代)
      在这里插入图片描述
    • 上图是JAVA8的HotSpot的分代策略
    • eden+S0+S1合起来称为年轻代(Young Generation),GC非常频繁
    • S0+S1 称为幸存区(Survivor Space)
    • Tenured称为老年代(Old Generation)
    • metasnace:元空间(存放不回收的东西)
年轻代(Young Generation):
  • Java应用在分配Java对象时,这些对象会被分配到年轻代堆空间中去
  • . 这个空间大多是小对象并且频繁回收
老年代(Old Generation):
  • 年轻代堆空间的长期存活对象会转移到(也许是永久性转移)年老代堆空间
  • 这个堆空间通常比年轻代的堆空间大,并且其空间增长速度较缓
持久代(metasnace):JDK8之后叫元空间
  • 存放JVM和Java类的元数据(metadata),以及interned字符串和类的静态变量

GC的回收过程:刚开始对象都会被分配到年轻代中,在年轻代中的对象会被进行计数,被频繁使用的对象会被调到幸存区(S0,S1)中,当对象经历多次GC仍然没有被清理,该对象会被认为有一个较长的生命周期,从而被移到年老代中,当年老代中对象到达一定数量时会自动fullgc一次清理掉。当然堆的大小都是可以修改的,结合当前机器的资源修改。
GC频率:当内存达到一定阈值的时候,触发阈值后自动回收(内存小很快到达阈值就会触发GC,内存大,需要很久才达到阈值)

Tips:eden被GC,如果没有被回收掉(进程还没释放,还有守护线程),就+1次,最高15之后被放到S0或S1继续GC,S0和S1互斥,eden要么分给SO,要么分S1,同样如果在S0或S1没有被GC掉,达到15次就会进入Tenured(老年代),到了老年代就不怎么GC或者GC很慢很慢

四、内存回收策略

  1. 回收策略:Mark-Sweep 标记清除,copying算法,Mark-Compact 标记压缩

    内存回收策略优点缺点
    Mark-Sweep 标记清除清除较快删除时会产生碎片,不够放大对象
    copying算法清理的同时进行整理,可以存放大对象浪费一半的空间
    Mark-Compact 标记压缩标记的时候进行整理,可以存放大对象速度慢,效率较低
  2. Mark-Sweep 标记清除如下图:适合老年代(只管回收,不管整理)
    在这里插入图片描述
    Tips:例如餐厅吃饭有空余的桌子空出来了,未使用的空间腾出来了,不做整理,只做标记

  3. copying算法 如下图:适合年轻代,S0和S1(浪费空间),如图要么使用上面一半,要么使用下面一半
    要么使用S0,要么使用S1,不会两个都用
    在这里插入图片描述

  4. Mark-Compact 标记压缩:JC不频繁,适合老年代
    在这里插入图片描述

Tips:
了解JAVA自己的回收机制,更有助于压测,内存如果不用了需要回收释放掉,如果不释放,就会报内存溢出
堆内存:先进先出(例如:进餐厅吃饭,先来的吃完先走)
栈内存:先进后出(例如:有一叠盘子,先放在最下面的最后使用)

五、查看项目使用的jdk版本

  1. 命令:java -version
    在这里插入图片描述
  2. 通过tomcat项目内查看
    进入到tomcat的bin目录下:cd /usr/local/tomcat7-8083/bin
    执行如下:./version.sh
    在这里插入图片描述
  3. 还可以通过tomcat的bin目录下的配置文件查看
    执行命令:cat catalina.sh
    在这里插入图片描述
  4. 设置如下
    在这里插入图片描述
    Xms 起始堆内存
    Xmx 最大堆内存
    PermSize 永久代,在1.8之后称之为元空间
    -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/tomcat7-8083/bin/dushi.hprof
    如果出现内存溢出,在对应的路径生成一个hprof文件
    -XX:NewRatio=2 新生代和老年代的比例(不写默认1:2),2代表年轻代占1,老年代占2

六:JVM性能监测工具visualvm安装及配置

  1. 下载地址 https://visualvm.github.io/download.html
    JDK1.8之前自带JvisualVM,不需要下载,直接使用.在java的bin目录下,可以找到JvisualVM.exe
    JDK比较新的版本,不自带这个工具,那么需要下载并安装.工具的名字也变为了VisualVM
    默认在C盘:C:\Program Files\Java\jdk1.8.0_211\bin
  2. 双击打开,如果需要监控GC,那么要配置一个GC插件,工具→插件→可用插件,选择visual GC,点击左下角的安装
    如果自行安装的版本,需要在运行之前进行配置,进入viusalvm的etc目录,打开visualvm.conf,在大约72行的位置添加一行jdk的路径:visualvm_jdkhome=“你的jdk的路径”
    在这里插入图片描述

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

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

相关文章

盛世欢歌,共庆华诞!祝大家国庆节快乐!

举国同庆 盛世中华 盛世欢歌,共庆华诞!在这美好的时光里,让我们一起欢庆国庆,感受祖国的强大和美好。数图祝大家国庆快乐! 国庆来临之际,根据国家有关规定,现将2024年国庆放假安排通知如下&…

JVM(HotSpot):虚拟机栈(JVM Stacks)与本地方法栈(Native Method Stacks)

文章目录 一、内存结构图二、数据结构-栈三、JVM栈四、本地方法栈五、问题辨析1、垃圾回收是否涉及栈内存?2、栈内存越大越好吗?3、方法内的局部变量是否线程安全?4、栈内存溢出问题 一、内存结构图 二、数据结构-栈 数据结构中,…

windows 系统服务在注册表中的位置

计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services 此注册表项下是系统服务安装信息 利用此注册表项可以获取服务详细信息

新版Android Studio Koala 导入github第三方依赖 maven仓库的处理方法 (java版)

以下是依赖的处理 这是由于Android Studio 构建项目模式发生改变了。 旧版项目构造 创建新的项目采用build.gradle.kts配置。 先看旧版同样的配置是什么样的。 再来查看新版带.kts后缀文件官方自带的库是怎么配置,模拟配置就OK。 先看libs文件这个库的写法。 …

隐藏SpringBoot自动生成的文件

第一种方法——删除 第二种方法——Settings——Editor——fail types

题库系统平台开发功能解析

题库系统开发功能介绍可以从多个方面进行阐述,以下是一些核心功能及其详细解释 1. 题库管理系统 题目录入与编辑:提供灵活的题目录入方式,支持手动输入、批量导入(如从Excel、Word等文件中导入)以及从其他题库中复制试…

HuggingChat macOS版正式发布!文章内附体验地址!我国打造糖尿病专用AI模型|AI日报

文章推荐 全新豆包AI视频模型发布!实测下的可灵与豆包!原来它们的差距不止一点点... 今日热点 我国团队打造糖尿病专用AI模型 上海交通大学清源研究院MIFA实验室携手复旦大学附属中山医院内分泌科,组建专家团队,联手开发一款名…

Spring Boot项目连接Oracle数据库启动报错:Undefined Error

描述:远程拉下来的代码,配置了maven仓库后,未进行其他修改,自己本地启动报错。 报错现状: 解决:添加参数-Duser.nameuser后,启动成功。 原因分析: 分析一: maven仓…

Altium Designer脚本系统内置函数汇总(2417个)

Altium Designer脚本系统内置函数汇总(2417个) ↑↑↑点击上方蓝字,关注我们! Altium Designer 2013脚本系统内置函数,一共2417个。 这些函数名称复制到Altium Designer 2013脚本编辑器中会自动变为褐红色(#800000),内部函数大部分…

跨境必备:3个必不可少的低预算营销渠道

不管是跨境电商卖家还是外贸从业人员,从个体到企业或品牌,流量都是宣传营销领域的重点。有流量才能让更多的消费者看到自己的产品,从而有机会了解产品并促成转化。 各大跨境电商平台、社交媒体平台和搜索引擎等平台都提供了付费营销功能&…

16.网络编程(下篇)

目录 1.网络编程概述 2.应用软件架构 3.网络编程三要素-IP地址 4.网络编程三要素-端口与协议 5.UDP通信程序 6.TCP通信程序 1.网络编程概述 1.1计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系…

【问题解决】win10日志错误:创建 TLS 客户端凭据时发生致命错误。 内部错误状态为 10013

背景 最近win10死机了一次,查看事件管理器发现有大量的报错:“创建 TLS 客户端凭据时发生致命错误。 内部错误状态为 10013”,如图: 解决 win键搜索internet选项 确定。 原因 参考错误:“ 创建 TLS 客户端凭据…

C++基础知识9 模版进阶

模版进阶 1. 非类型模板参数2. 模板的特化2.1 概念2.2 函数模板特化2.3 类模板特化2.3.1 全特化2.3.2 偏特化2.3.3 类模板特化应用示例 3 模板分离编译3.1 什么是分离编译3.2 模板的分离编译3.3 解决方法 4. 模板总结 1. 非类型模板参数 模板参数分类类型形参与非类型形参。 类…

有些硬盘录像机接入视频汇聚平台EasyCVR后通道不显示/显示不全,该如何处理?

EasyCVR视频监控汇聚管理平台是一款针对大中型项目设计的跨区域网络化视频监控集中管理平台。该平台不仅具备视频资源管理、设备管理、用户管理、运维管理和安全管理等功能,还支持多种主流标准协议,如GB28181、RTSP/Onvif、RTMP、部标JT808、GA/T 1400协…

C#获取变量的数据类型_C#获取对象的数据类型

C#中的数据类型用 Type 类描述,具体的类型是 Type的对象 一、object.GetType() 对象.GetType()-----对象不能为null,否则运行报错; 通用的获取类型方式 底层对象获取类型,所有的对象,变量获取类型,GetType(); 返回的…

JAVA打造全球商品集散地国际版多商户商城系统小程序源码

打造全球商品集散地 —— 国际版多商户商城系统 🌍【开篇:连接世界,触手可及】🌍 在这个全球化的时代,购物不再受地域限制,每一个消费者都渴望能轻松买到来自世界各地的优质商品。而“打造全球商品集散地”…

快速实现AI搜索!Fivetran 支持 Milvus 作为数据迁移目标

Fivetran 现已支持 Milvus 向量数据库作为数据迁移的目标,能够有效简化 RAG 应用和 AI 搜索中数据源接入的流程。 数据是 AI 应用的支柱,无缝连接数据是充分释放数据潜力的关键。非结构化数据对于企业搜索和检索增强生成(RAG)聊天…

深度学习500问——Chapter17:模型压缩及移动端部署(1)

文章目录 17.1 模型压缩理解 17.2 为什么需要模型压缩和加速 17.3 模型压缩的必要性及可行性 17.4 目前有哪些深度学习模型压缩方法 17.4.1 前段压缩和后端压缩对比 17.4.2 网络剪枝 17.4.3 典型剪枝方法对比 17.4.4. 网络蒸馏 17.4.5 前端压缩 17.4.6 后端压缩 深度神经网络在…

刚毕业就做项目经理,现在感觉越做越没动力,还有必要坚持下去吗?

那种一毕业就做项目经理的,以为是少走10年弯路,干了一年后,才发现这简直就是在坑自己。没点真材实料,经理也变成了“空中架子”。 因此,很多一毕业就当上项目经理的人,要么是干着干着就转回到技术岗位&…

AI数字人:终于知道视频号咋爆的了

点击下方👇“拂晓AI数字人”关注公众号 一起学习AI 数字人,让服务更高效! 做视频号是不是有这种感觉,辛辛苦苦剪了几个小时的视频,上去就是几百播放量,就没有流量了,很抓狂。 找别人的爆的视频&…