java面试题-JVM问题排查
1.常见的Linux定位问题的工具?
常见的 Linux 定位问题的命令可以分为以下几类:
系统状态命令:包括 top、uptime、vmstat、sar 等命令,用于查看系统整体的状态,如 CPU 使用率、内存使用率、磁盘 I/O 等。
进程状态命令:包括 ps、pstree、pgrep、kill 等命令,用于查看进程的状态,如进程 ID、进程占用的资源等。
网络状态命令:包括 ifconfig、ip、netstat、ss、tcpdump 等命令,用于查看网络接口、网络连接状态、网络流量等。
文件状态命令:包括 lsof、fuser、df、du 等命令,用于查看文件句柄、文件系统状态、磁盘使用情况等。
Java 应用状态命令:包括 jps、jstat、jmap、jstack、jinfo 等命令,用于查看 Java 应用程序的状态,如 Java 进程 ID、内存使用情况、线程状态等。
2.JDK自带的定位问题的工具?
jps
jps (Java Process Status Tool) 是一个命令行工具,用于列出系统中所有正在运行的 Java 进程的进程 ID。可以用于确认 Java 进程是否已经启动,以及进程的 PID,便于后续进行进一步的诊断。
jps 命令常用的参数如下:
-q:只输出进程 ID,不输出类名和参数;
-m:输出主类名和参数;
-l:输出完整的包名、类名和参数。
使用示例:
jps // 输出所有 Java 进程的进程 ID 和类名
jps -q // 只输出进程 ID
jps -m // 输出主类名和参数
jps -l // 输出完整的包名、类名和参数
jstat
jstat (JVM Statistics Monitoring Tool) 是一个命令行工具,用于监控 Java 应用程序的各种状态信息,如垃圾回收、类加载、内存、线程等。可以帮助开发人员了解应用程序的实时状态,发现性能瓶颈和内存泄漏等问题。
jstat 命令常用的参数如下:
-gcutil:显示 GC 情况的统计信息,包括 Eden 区、Survivor 区和老年代的使用情况、GC 时间、GC 频率等;
-gcnew:显示新生代的 GC 情况,包括 Eden 区和 Survivor 区的使用情况、GC 时间、GC 频率等;
-gcold:显示老年代的 GC 情况,包括老年代的使用情况、GC 时间、GC 频率等;
-gcpermcapacity:显示永久代的使用情况,包括永久代的使用量、使用率等;
-gcnewcapacity:显示新生代的使用情况,包括 Eden 区和 Survivor 区的使用量、使用率等;
-gccapacity:显示各个区域的容量情况,包括 Eden 区、Survivor 区和老年代的容量、使用量、使用率等;
-class:显示类加载器的加载类的数量、类加载器的数量、已卸载的类的数量等信息;
-compiler:显示 JIT 编译器的编译情况,包括编译任务数、编译失败的任务数、编译耗时等;
-printcompilation:显示 JIT 编译器编译方法的详细信息;
-uptime:显示 JVM 运行时间等信息。
使用示例:
jstat -gcutil 1234 // 监控进程 ID 为 1234 的 JVM 的 GC 情况
jstat -gcnewcapacity 1234 // 监控进程 ID 为 1234 的 JVM 的新生代的使用情况
jstat -class 1234 // 监控进程 ID 为 1234 的 JVM 的类加载器的信息
上述命令会每隔 1 秒(1000 毫秒)输出一次 PID 为 <pid> 的 Java 应用程序的 GC 相关信息,一共输出 10 次。
jmap
jmap (JVM Memory Map Tool) 是一个命令行工具,用于生成 Java 应用程序的内存映像,包括堆内存、非堆内存、PermGen/Metaspace 等。可以用于查看内存使用情况、定位内存泄漏等问题。
以下是jmap的常用命令及其作用:
jmap -heap <pid>:打印Java进程的堆内存信息,包括使用的垃圾回收器、堆大小、新生代大小、新生代中Eden区、Survivor区的比例等。
jmap -histo <pid>:输出Java进程中各个类的实例数量和占用空间大小。可以通过该命令查看某个类的实例数量,以及这些实例的内存使用情况。
jmap -dump:live,format=b,file=<filename> <pid>:生成Java进程的堆转储快照。-dump参数指定生成转储快照,live表示只转储堆中存活的对象,format=b表示生成二进制格式的转储快照,file=<filename>指定生成的转储快照文件名。
需要注意的是,jmap会暂停Java进程的运行,生成堆转储快照期间会影响应用程序的性能,应尽量避免在生产环境中使用。同时,由于jmap需要读取Java进程的内存信息,需要具有相应的权限才能使用。
使用示例:
jmap -dump:format=b,file=heapdump.bin <pid>
上述命令会生成一个名为 heapdump.bin 的二进制文件,保存了 PID 为 <pid> 的 Java 应用程序的内存信息。
jstack
jstack (JVM Stack Trace Tool) 是一个命令行工具,用于生成 Java 应用程序的线程转储信息,可以帮助开发人员定位死锁等线程相关的问题。
jstack [-l] <pid>
其中,-l 表示输出详细的锁信息。<pid> 表示 Java 进程的进程 ID。如果省略 -l 参数,则只输出线程的调用栈信息。
使用示例:
使用jstack命令生成线程快照。
$ jstack 12456 > threads.txt
上述命令将生成一个名为threads.txt的文件,其中包含Java进程中所有线程的堆栈跟踪信息。
JStat
JStat 是 JDK 自带的一款命令行工具,用于查看 JVM 的统计信息。它可以查看 JVM 中的垃圾回收信息、类加载信息、线程状态等,帮助开发人员快速了解 JVM 的运行情况。
以下是JStat常用的选项:
-class:监视类装载、卸载情况。
-gc:监视垃圾回收情况。
-compiler:监视JIT编译情况。
-gcutil:输出垃圾回收统计信息,包括堆使用情况、GC时间、各种GC事件等。
-gcnew:输出新生代垃圾回收统计信息。
-gcold:输出老年代垃圾回收统计信息。
-util:输出各种内存池的使用情况。
JStat的使用非常简单,只需要在命令行中输入"jstat"加上相应的选项和JVM进程ID即可。例如:
jstat -gcutil 1234
这条命令将输出JVM进程ID为1234的垃圾回收统计信息。JStat输出的结果类似于下面这样:
S0 S1 E O P YGC YGCT FGC FGCT GCT 0.00 66.85 29.35 67.92 52.90 2342 27.755 3 0.204 27.959
其中,S0和S1是新生代中的两个Survivor区域的使用情况,E是新生代中Eden区域的使用情况,O是老年代的使用情况,P是永久代的使用情况。YGC表示Young GC的次数,YGCT表示Young GC所花费的时间,FGC表示Full GC的次数,FGCT表示Full GC所花费的时间,GCT表示总的GC时间。
相关文章:
java面试题-JVM问题排查
1.常见的Linux定位问题的工具?常见的 Linux 定位问题的命令可以分为以下几类:系统状态命令:包括 top、uptime、vmstat、sar 等命令,用于查看系统整体的状态,如 CPU 使用率、内存使用率、磁盘 I/O 等。进程状态命令&…...

市场上有很多低代码开发平台,不懂编程的人可以用哪些?
市场上有很多低代码开发平台,不懂编程的人可以用哪些?这个问题一看就是外行问的啦,低代码平台主打的就是一个“全民开发”,而且现在很多低代码平台都发展为零代码了,不懂编程也完全可以使用! 所谓低代码开…...

Tina_Linux打包流程说明指南_new
OpenRemoved_Tina_Linux_打包流程_说明指南_new 1 概述 1.1 编写目的 介绍Allwinner 平台上打包流程。 1.2 适用范围 Allwinner 软件平台Tina v3.0 版本以上。 1.3 相关人员 适用Tina 平台的广大客户,想了解Tina 打包流程的开发人员。 2 固件打包简介 固件…...
JVM面试题
JVM 1.jvm的组成部分 类加载器:将javac编译的class文件加载到内存中 运行时数据区:将内存划分成若干个不同的区域。 执行引擎:负责解析命令,提交操作系统执行。 本地接口:融合不同的语言为java所用 2.运行时数据区 方法区&…...
@FeignClient注解
1.在启动类上开启Feign功能 不开会提示找不到所需要的bean Consider defining a bean of type in your configuration SpringBootApplication EnableFeignClients public class AuthApplication {public static void main(String[] args) {SpringApplication.run(AuthApplic…...
一文搞懂如何在 React 中使用 防抖(Debounce)和 节流(Throttle)
在前端的日常开发中,经常会使用到两个函数防抖(Debounce)和节流(Throttle),防抖函数可以有效控制在一段时间内只执行最后一次请求,例如搜索框输入时,只在输入完成后才进行请求接口。…...
Airbyte API
Airbyte API涵盖了Airbyte功能的方方面面,主要分类:Source_definition:来源定义,实现了来源的增删改查功能。Destination_definition:目标定义,实现了目标的增删改查功能。Workspace:工作区管理…...
vue项目使用Electron开发桌面应用
添加npm配置避免安装Electron错误 请确保您的 node 版本大于等于 18. cmd运行: npm config edit 该命令会打开npm的配置文件,请在空白处添加: electron_builder_binaries_mirrorhttps://npmmirror.com/mirrors/electron-builder-binaries/ e…...

std::chrono笔记
文章目录1. radio原型作用示例2. duration原型:作用示例3. time_point原型作用示例4. clockssystem_clock示例steady_clock示例high_resolution_clock先说感觉,这个库真恶心,刚接触感觉跟shi一样,特别是那个命名空间,太…...
接收arp请求并发送回应的实例
本文简单介绍了arp协议,用一个实例查看收到的ARP请求,并对该请求发出ARP回应,实例有完整的源代码,使用C语言在Linux下实现,代码中有详细的注释。 1. ARP协议 ARP(Address Resolution Protocol),地址解析协议;在局域网上通过IP地址获取物理地址MAC的协议,该协议工作在数…...

【高性能计算】TVM使用TE手动优化矩阵乘法算法解析与代码解读
引言 注:本文主要介绍、解释TVM的矩阵优化思想、代码,需要配合代码注释一起阅读。 矩阵乘法是计算密集型运算。为了获得良好的 CPU 性能,有两个重要的优化措施: 提高内存访问的高速缓存命中率。复杂的数值计算和热点内存&#x…...

消息中间件的概念
中间件(middleware)是基础软件的一大类,属于可复用的软件范畴。中间件在操作系统软件,网络和数据库之上,应用软件之下,总的作用是为处于自己上层的应用软件提供运行于开发的环境,帮助用户灵活、高效的开发和集成复杂的…...

窃密恶意软件Raccoon最新样本Stealer v2分析
Raccoon 是一个恶意软件家族,2019 年来一直在地下犯罪论坛中以恶意软件即服务的身份进行售卖。2022 年 7 月,该恶意软件家族发布了 C 语言编写的新版本 Raccoon Stealer v2,打破了以往使用 C 开发的传统。 Raccoon 是一个信息窃密恶意软件&a…...

足球俱乐部管理系统
技术:Java、JSP等摘要:网站是一种主要的渠道。人们通过互联网快速、准确的发布信息、获取信息。而足球俱乐部是足球职业化、专业化的一个标志,是足球运动员以足球谋生时,所被聘用的机构,应运时代发展,规模、…...
2023上半年数学建模竞赛汇总(比赛时间、难易程度、含金量、竞赛官网)
1、美国大学生数学建模竞赛等级:国家级是否可跨校:否竞赛开始时间:2月17日~2月21日综合难度:⭐⭐⭐⭐ 竞赛含金量:⭐⭐⭐⭐⭐竞赛官网:https://www.comap.com/2、MathorCup高校数学建模挑战赛---大数据竞赛…...
【python学习笔记】:PHP7 Null合并运算符
在PHP7,一个新的功能,空合并运算符(??)已被引入。它被用来代替三元运算并与 isset()函数功能结合一起使用。如果它存在并且它不是空的,空合并运算符返回它的第一个操作数;否则返回第二个操作数。 示例 <?php// fetch the value of $_…...

数据结构与算法——3.时间复杂度分析1(概述)
前面我们已经介绍了,研究算法的最终目的是如何花费更少的时间,如何占用更少的内存去完成相同的需求,并且也通过案例演示了不同算法之间时间耗费和空间耗费上的差异,但我们并不能将时间占用和空间占用量化。因此,接下来…...

FPGA学习之日常工作复位电路
最近一个多月没有写博客了,然后最近工作中也遇到一个复位信号的问题。问题是这样的,关于外部复位信号,之前我们的处理方式都是通过PLL产生的Lock信号作为内部的复位信号。但是由于换到A54上面没有IP核,所以只有不用PLL,…...
【洛谷 P1177】【模板】快速排序 题解(快速排序+指针)
【模板】快速排序 题目描述 利用快速排序算法将读入的 NNN 个数从小到大排序后输出。 快速排序是信息学竞赛的必备算法之一。对于快速排序不是很了解的同学可以自行上网查询相关资料,掌握后独立完成。(C 选手请不要试图使用 STL,虽然你可以…...

Pthon--自动化实用技巧篇--文件目录处理
为什么要讲这一篇,主要是因为这个在自动化测试框架或者脚本的编写的时候会用到,还是比较方便的。看上述两个函数。getcwd()、chdir()。使用 os.getcwd() 函数获得当前工作目录。使用 os.chdir()函数改变当前工作目录。所以在用chdir()函数的时候别忘记指…...

Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...

【JVM】- 内存结构
引言 JVM:Java Virtual Machine 定义:Java虚拟机,Java二进制字节码的运行环境好处: 一次编写,到处运行自动内存管理,垃圾回收的功能数组下标越界检查(会抛异常,不会覆盖到其他代码…...
大模型多显卡多服务器并行计算方法与实践指南
一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...
C++八股 —— 单例模式
文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全(Thread Safety) 线程安全是指在多线程环境下,某个函数、类或代码片段能够被多个线程同时调用时,仍能保证数据的一致性和逻辑的正确性…...

有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...

使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...

初学 pytest 记录
安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...
蓝桥杯 冶炼金属
原题目链接 🔧 冶炼金属转换率推测题解 📜 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V,是一个正整数,表示每 V V V 个普通金属 O O O 可以冶炼出 …...
Java + Spring Boot + Mybatis 实现批量插入
在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法:使用 MyBatis 的 <foreach> 标签和批处理模式(ExecutorType.BATCH)。 方法一:使用 XML 的 <foreach> 标签ÿ…...

安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲
文章目录 前言第一部分:体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分:体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...