Java程序的故障排查

文章目录

    • Linux命令
      • 关机/重启/注销
      • 系统信息和性能查看
      • 磁盘和分区
      • ⽤户和⽤户组
      • ⽹络和进程管理
      • 常⻅系统服务命令
      • ⽂件和⽬录操作
      • ⽂件查看和处理
      • 打包和解压
      • RPM包管理命令
      • YUM包管理命令
      • DPKG包管理命令
      • APT软件⼯具
    • JDK命令
      • jps
      • jstat
      • jinfo
      • jmap
      • jhat
      • jstack
      • jcmd
      • jconsole
    • 分析工具
      • VisualVM
      • Eclipse MAT

Linux命令

由于大多数Java程序部署到Linux服务器上,故障排查和性能调优通常需要结合使用Linux命令。Linux命令,可以实时查看系统的CPU、内存、磁盘和网络使用情况,帮助识别和解决系统级别的问题。常见的命令包括top用于显示实时的CPU和内存使用情况,df查看磁盘使用情况,netstat显示网络连接和监听端口,ping测试网络延迟,systemctl管理系统服务等。

关机/重启/注销

常用命令作用
shutdown -h now即刻关机
shutdown -h 1010分钟后关机
shutdown -h 11:0011:00关机
shutdown -h +10预定时间关机(10分钟后)
shutdown -c取消指定时间关机
shutdown -r now重启
shutdown -r 1010分钟之后重启
shutdown -r 11:00定时重启
reboot重启
init 6重启
init 0⽴刻关机
telinit 0关机
poweroff⽴刻关机
halt关机
syncbuff数据同步到磁盘
logout退出登录Shell

系统信息和性能查看

常用命令作用
uname -a查看内核/OS/CPU信息
uname -r查看内核版本
uname -m查看处理器架构
arch查看处理器架构
hostname查看计算机名
who显示当前登录系统的⽤户
who am i显示登录时的⽤户名
whoami显示当前⽤户名
cat /proc/version查看linux版本信息
cat /proc/cpuinfo查看CPU信息
cat /proc/interrupts查看中断
cat /proc/loadavg查看系统负载
uptime查看系统运⾏时间、⽤户数、负载
env查看系统的环境变量
lsusb -tv查看系统USB设备信息
lspci -tv查看系统PCI设备信息
lsmod查看已加载的系统模块
grep MemTotal /proc/meminfo查看内存总量
grep MemFree /proc/meminfo查看空闲内存量
free -m查看内存⽤量和交换区⽤量
date显示系统⽇期时间
cal 2021显示2021⽇历表
top动态显示cpu/内存/进程等情况
vmstat 1 20每1秒采⼀次系统状态,采20次
iostat查看io读写/cpu使⽤情况
查看io读写/cpu使⽤情况查询cpu使⽤情况(1秒⼀次,共10次)
sar -d 1 10查询磁盘性能

磁盘和分区

常用命令作用
fdisk -l查看所有磁盘分区
swapon -s查看所有交换分区
df -h查看磁盘使⽤情况及挂载点
df -hl同上
du -sh /dir查看指定某个⽬录的⼤⼩
du -sk * | sort -rn从⾼到低依次显示⽂件和⽬录⼤⼩
mount /dev/hda2 /mnt/hda2挂载hda2盘
mount -t ntfs /dev/sdc1 /mnt/usbhd1指定⽂件系统类型挂载(如ntfs)
mount -o loop xxx.iso /mnt/cdrom挂 载 iso ⽂ 件
umount -v /dev/sda1通过设备名卸载
umount -v /mnt/mymnt通过挂载点卸载
fuser -km /mnt/hda1强制卸载(慎⽤)

⽤户和⽤户组

常用命令作用
useradd codesheep创建⽤户
userdel -r codesheep删除⽤户
usermod -g group_name user_name修改⽤户的组
usermod -aG group_name user_name将⽤户添加到组
usermod -s /bin/ksh -d /home/codepig –g dev codesheep修改⽤户codesheep的登录Shell、主⽬录以及⽤户组
groups test查看test⽤户所在的组
groupadd group_name创建⽤户组
groupdel group_name删除⽤户组
groupmod -n new_name old_name重命名⽤户组
su - user_namesu - user_name
passwd修改⼝令
passwd codesheep修改某⽤户的⼝令
w查看活动⽤户
id codesheep查看指定⽤户codesheep信息
last查看⽤户登录⽇志
crontab -l查看当前⽤户的计划任务
cut -d: -f1 /etc/passwd查看系统所有⽤户
cut -d: -f1 /etc/group查看系统所有组

⽹络和进程管理

常用命令作用
ifconfig查看⽹络接⼝属性
ifconfig eth0查看某⽹卡的配置
route -n查看路由表
netstat -lntp查看所有监听端⼝
netstat -antp查看已经建⽴的TCP连接
netstat -lutp查看TCP/UDP的状态信息
ifup eth0启⽤eth0⽹络设备
ifdown eth0禁⽤eth0⽹络设备
iptables -L查看iptables规则
ifconfig eth0 192.168.1.1 netmask 255.255.255.0配置ip地址
dhclient eth0以dhcp模式启⽤eth0
route add -net 0/0 gw Gateway_IP配置默认⽹关
route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1配置静态路由到达⽹络’192.168.0.0/16’
route del 0/0 gw Gateway_IP删除静态路由
hostname查看主机名
host www.baidu.com解析主机名
nslookup www.baidu.com查询DNS记录,查看域名解析是否正常
ps -ef查看所有进程
ps -ef | grep codesheep过滤出你需要的进程
kill -s namekill指定名称的进程
kill -s pidkill指定pid的进程
top实时显示进程状态
vmstat 1 20每1秒采⼀次系统状态,采20次
iostatiostat
sar -u 1 10查询cpu使⽤情况(1秒⼀次,共10次)
sar -d 1 10查询磁盘性能

常⻅系统服务命令

常用命令作用
chkconfig --list列出系统服务
service <服务名> status查看某个服务
service <服务名> start启动某个服务
service <服务名> stop终⽌某个服务
service <服务名> restart重启某个服务
systemctl status <服务名>查看某个服务
systemctl start <服务名>启动某个服务
systemctl stop <服务名>终⽌某个服务
systemctl restart <服务名>重启某个服务
systemctl enable <服务名>关闭⾃启动
systemctl disable <服务名>关闭⾃启动

⽂件和⽬录操作

常用命令作用
cd <⽬录名>进⼊某个⽬录
cd …回上级⽬录
cd …/…回上两级⽬录
cd进个⼈主⽬录
cd -回上⼀步所在⽬录
pwd显示当前路径
ls查看⽂件⽬录列表
ls -F查看⽬录中内容(显示是⽂件还是⽬录)
ls -l查看⽂件和⽬录的详情列表
ls -a查看隐藏⽂件
ls -lh查看⽂件和⽬录的详情列表(增强⽂件⼤⼩易读性)
ls -lSr查看⽂件和⽬录列表(以⽂件⼤⼩升序查看)
tree查看⽂件和⽬录的树形结构
mkdir <⽬录名>创建⽬录
mkdir dir1 dir2同时创建两个⽬录
mkdir -p /tmp/dir1/dir2创建⽬录树
rm -f file1删除’file1’⽂件
rmdir dir1删除’dir1’⽬录
rm -rf dir1删除’dir1’⽬录和其内容
rm -rf dir1 dir2同时删除两个⽬录及其内容
mv old_dir new_dir重命名/移动⽬录
cp file1 file2复制⽂件
cp dir/* .复制某⽬录下的所有⽂件⾄当前⽬录
cp -a dir1 dir2复制⽬录
cp -a /tmp/dir1 .复制⼀个⽬录⾄当前⽬录
ln -s file1 link1创建指向⽂件/⽬录的软链接
ln file1 lnk1创建指向⽂件/⽬录的物理链接
find / -name file1从跟⽬录开始搜索⽂件/⽬录
find / -user user1搜索⽤户user1的⽂件/⽬录
find /dir -name *.bin在⽬录/dir中搜带有.bin后缀的⽂件
locate <关键词>快速定位⽂件
locate *.mp4寻找.mp4结尾的⽂件
whereis <关键词>显示某⼆进制⽂件/可执⾏⽂件的路径
which <关键词>查找系统⽬录下某的⼆进制⽂件
chmod ugo+rwx dir1设置⽬录所有者(u)、群组(g)及其他⼈(o)的读(r)写(w)执⾏(x)权限
chmod go-rwx dir1移除群组(g)与其他⼈(o)对⽬录的读写执⾏权限
chown user1 file1改变⽂件的所有者属性
chown -R user1 dir1改变⽬录的所有者属性
chgrp group1 file1改变⽂件群组
chown user1:group1 file1改变⽂件的所有⼈和群组

⽂件查看和处理

常用命令作用
cat file1查看⽂件内容
cat -n file1查看内容并标示⾏数
tac file1从最后⼀⾏开始反看⽂件内容
more file1more file1
less file1类似more命令,但允许反向操作
head -2 file1查看⽂件前两⾏
tail -2 file1查看⽂件后两⾏
tail -f /log/msg实时查看添加到⽂件中的内容
grep codesheep hello.txt在⽂件hello.txt中查找关键词codesheep
grep ^sheep hello.txt在⽂件hello.txt中查找以sheep开头的内容
grep [0-9] hello.txt选择hello.txt⽂件中所有包含数字的⾏
sed ‘s/s1/s2/g’ hello.txt将hello.txt⽂件中的s1替换成s2
sed ‘/^$/d’ hello.txt从hello.txt⽂件中删除所有空⽩⾏
sed ‘/ *#/d; /^$/d’ hello.txt从hello.txt⽂件中删除所有注释和空⽩⾏
sed -e ‘1d’ hello.txt从⽂件hello.txt 中排除第⼀⾏
sed -n ‘/s1/p’ hello.txt查看只包含关键词"s1"的⾏
sed -e ‘s/ *$//’ hello.txt删除每⼀⾏最后的空⽩字符
sed -e ‘s/s1//g’ hello.txt从⽂档中只删除词汇s1并保留剩余全部
sed -n ‘1,5p;5q’ hello.txt查看从第⼀⾏到第5⾏内容
sed -n ‘5p;5q’ hello.txt查看第5⾏
paste file1 file2合并两个⽂件或两栏的内容
paste -d ‘+’ file1 file2合并两个⽂件或两栏的内容,中间⽤"+"区分
sort file1 file2排序两个⽂件的内容
comm -1 file1 file2⽐较两个⽂件的内容(去除’file1’所含内容)
comm -2 file1 file2⽐较两个⽂件的内容(去除’file2’所含内容
comm -3 file1 file2⽐较两个⽂件的内容(去除两⽂件共有部分)

打包和解压

常用命令作用
zip xxx.zip file压缩⾄zip包
zip -r xxx.zip file1 file2 dir1将多个⽂件+⽬录压成zip包
unzip xxx.zip解压zip包
tar -cvf xxx.tar file创建⾮压缩tar包
tar -cvf xxx.tar file1 file2 dir1将多个⽂件+⽬录打tar包
tar -tf xxx.tar查看tar包的内容
tar -xvf xxx.tar解压tar包
tar -xvf xxx.tar -C /dir将tar包解压⾄指定⽬录
tar -cvfj xxx.tar.bz2 dir创建bz2压缩包
tar -jxvf xxx.tar.bz2解压bz2压缩包
tar -cvfz xxx.tar.gz dir创建gzip压缩包
tar -zxvf xxx.tar.gz解压gzip压缩包
bunzip2 xxx.bz2解压bz2压缩包
bzip2 filename压缩⽂件
gunzip xxx.gz解压gzip压缩包
gzip filename压缩⽂件
gzip -9 filename最⼤程度压缩

RPM包管理命令

常用命令作用
rpm -qa查看已安装的rpm包
rpm -q pkg_name查询某个rpm包
rpm -q --whatprovides xxx显示xxx功能是由哪个包提供的
rpm -q --whatrequires xxx显示xxx功能被哪个程序包依赖的
rpm -q --changelog xxx显示xxx包的更改记录
rpm -qi pkg_name查看⼀个包的详细信息
rpm -qd pkg_name查询⼀个包所提供的⽂档
rpm -qc pkg_name查看已安装rpm包提供的配置⽂件
rpm -ql pkg_name查看⼀个包安装了哪些⽂件
rpm -qf filename查看某个⽂件属于哪个包
rpm -qR pkg_name查询包的依赖关系
rpm -ivh xxx.rpm安装rpm包
rpm -ivh --test xxx.rpm测试安装rpm包
rpm -ivh --nodeps xxx.rpm安装rpm包时忽略依赖关系
rpm -e xxx卸载程序包
rpm -Fvh pkg_name升级确定已安装的rpm包
rpm -Uvh pkg_name升级rpm包(若未安装则会安装)
rpm -V pkg_nameRPM包详细信息校验

YUM包管理命令

常用命令作用
yum repolist enabled显示可⽤的源仓库
yum search pkg_name搜索软件包
yum install pkg_name下载并安装软件包
yum install --downloadonly pkg_name只下载不安装
yum list显示所有程序包
yum list installed查看当前系统已安装包
yum list updates查看可以更新的包列表
yum check-update查看可升级的软件包
yum update更新所有软件包
yum update pkg_name升级指定软件包
yum deplist pkg_name列出软件包依赖关系
yum remove pkg_name删除软件包
yum clean all清除缓存
yum clean packages清除缓存的软件包
yum clean headers清除缓存的header

DPKG包管理命令

常用命令作用
dpkg -c xxx.deb列出deb包的内容
dpkg -i xxx.deb安装/更新deb包
dpkg -r pkg_name移除deb包
dpkg -P pkg_name移除deb包(不保留配置)
dpkg -l查看系统中已安装deb包
dpkg -l pkg_name显示包的⼤致信息
dpkg -L pkg_name查看deb包安装的⽂件
dpkg -s pkg_name查看包的详细信息
dpkg –unpack xxx.deb解开deb包的内容

APT软件⼯具

常用命令作用
apt-cache search pkg_name搜索程序包
apt-cache show pkg_name获取包的概览信息
apt-get install pkg_name安装/升级软件包
apt-get purge pkg_name卸载软件(包括配置)
apt-get remove pkg_name卸载软件(不包括配置)
apt-get update更新包索引信息
apt-get upgrade更新已安装软件包
apt-get clean清理缓存

JDK命令

JDK命令用于诊断和优化Java应用程序的性能,分析JVM行为。通过这些命令,可以生成和分析堆转储,查看线程状态,获取JVM配置信息等。常用命令包括jmap用于生成堆转储,jstack打印线程堆栈跟踪,jstat查看垃圾回收统计信息,jinfo获取JVM系统属性和配置信息,javap反编译类文件。

jps

jps是JDK提供的一个命令行工具,用于列出正在运行的JVM实例。它显示所有Java进程的进程ID和主类名。

命令描述
jps -l显示完整的主类名或 JAR 文件名
jps -v显示 JVM 启动时的参数
jps -m显示传递给 main 方法的参数
jps -q只显示进程 ID,不显示主类名或其他信息
jps -J将参数传递给 jps 命令的 JVM

jstat

jstat命令是JDK提供的一个工具,用于监视JVM的性能和运行时统计信息。它提供了多种选项来获取JVM内存、垃圾回收、编译和类加载的详细统计数据。通过jstat,可以实时获取JVM内部的各种状态信息,有助于性能监控和故障排查。

命令描述
jstat -gc <pid>显示垃圾回收相关的统计信息
jstat -gccapacity <pid>显示 GC 内存区容量的统计信息
jstat -gcnew <pid>显示新生代的垃圾回收统计信息
jstat -gcold <pid>显示老年代的垃圾回收统计信息
jstat -gcutil <pid>显示各个内存区域的使用情况
jstat -printcompilation <pid>显示正在编译的 Java 类的相关信息
jstat -compiler <pid>显示编译器相关的统计信息
jstat -class <pid>显示类加载相关的统计信息
jstat -classload <pid>显示类加载的统计信息
jstat -heap <pid>显示 JVM 堆的使用情况
jstat -stack <pid>显示线程栈的统计信息

jinfo

jinfo命令是JDK提供的一个工具,用于显示JVM的配置信息和系统属性。jinfo查看虚拟机参数信息,也可用于调整虚拟机配置参数。

命令描述
jinfo -flags <pid>显示 JVM 启动时使用的所有标志和标志信息
jinfo -sysprops <pid>显示 JVM 启动时设置的系统属性
jinfo -heap <pid>显示 JVM 的堆内存设置,包括堆的初始大小和最大大小
jinfo -l <pid>显示进程的锁信息,例如线程持有的锁和锁的竞争情况
jinfo -version <pid>显示 JVM 的版本信息
jinfo -x <pid>显示 JVM 的详细运行时信息,包括垃圾回收信息和类加载信息
jinfo -jdwp <pid>显示 JDWP (Java Debug Wire Protocol) 相关信息
jinfo -stack <pid>显示进程的线程栈信息
jinfo -set <option=value> <pid>动态设置 JVM 参数,例如调整垃圾回收器的行为

当使用jinfo进行修改对应进程JVM参数时,有一定的局限性。并不是所有的参数都支持修改,只有参数被标记为manageable的参数才可以被实时修改。可以使用命令查看被标记为manageable的参数,java -XX:+PrintFlagsFinal -version | grep manageable

jmap

jmap命令用于生成JVM的内存映像,可以帮助开发人员分析内存使用情况,进行内存泄漏检测和性能优化。它能够生成堆转储、查看堆的摘要信息、以及查看堆的使用情况等。jmap命令可以获得运行中的JVM的堆的快照,从而可以离线分析堆,来检查内存泄漏、检查一些严重影响性能的大对象的创建、检查系统中什么对象最多,各种对象所占内存的大小等等。可以使用jmap生成Heap Dump文件。

命令描述
jmap -dump:format=b,file=<file> <pid>生成堆转储文件,格式为 b 表示二进制格式,file 是输出的文件名
jmap -heap <pid>显示堆内存的详细信息,包括堆的初始大小、最大大小和各个内存区域的使用情况
jmap -histo <pid>显示堆中对象的类和它们的实例数量,帮助分析内存中存储的对象
jmap -finalizerinfo <pid>显示所有对象的 finalizer 信息,帮助识别未及时清理的对象
jmap -stack <pid>显示堆栈的内容,包括线程堆栈信息,主要用于线程分析
jmap -F <pid>强制执行操作,适用于当进程在特定状态下时,确保 jmap 命令能够成功执行

Heap Dump又叫堆转储文件,指一个Java进程在某一个时间点的内存快照文件。Heap Dump在触发内存快照的时候会保存以下信息:

  • 所有的对象
  • 所有的class
  • GC Roots
  • 本地方法栈和本地变量

通常在写dump文件前会触发一次Full GC,所以Heap Dump文件里保存的对象都是Full GC后保留的对象信息。
由于生成dump文件比较耗时,所以请耐心等待,尤其是大内存镜像生成的dump文件,则需要更长的时间来完成。

可以通过参数配置当发生OOM时自动生成Heap dump文件:

-XX:+HeapDumpOnOutOfMemeryError -XX:+HeapDumpPath=<filename.hprof>

当然此种方式获取dump文件较大,如果想要获取dump文件较小可以手动获取dump文件并指定只获取存活的对象。

jhat

jhat是一个用于分析Java堆转储的工具。它可以提供一个网页界面,用于查看堆转储文件中的对象信息、对象引用和内存使用情况等。jhat内置了一个微型的HTTP/HTML服务器,生成dump的分析结果后,可以在浏览器中查看。但是一般不会直接在服务器上进行分析,因为jhat是一个耗时并且耗费硬件资源的过程,一般把服务器生成的dump文件复制到本地或其他机器上进行分析。所以jhat在JDK9中已经移除,官方推荐使用visualvm来分析dump文件。

命令描述
jhat <file>启动 jhat 工具并加载指定的堆转储文件 <file>,默认在本地服务器上提供一个网页界面
jhat -d <seconds> <file>启动 jhat 工具并将堆转储文件 <file> 加载到内存中,-d 选项指定分析超时时间
jhat -heap <file>显示堆内存的摘要信息和分析结果,包括堆的各个区域的内存使用情况

jstack

jstack是一个Java工具,用于用于生成虚拟机指定进程当前线程快照。它能帮助开发人员诊断线程死锁、线程阻塞等问题。jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多。

命令描述
jstack <pid>打印指定进程 ID <pid> 的线程堆栈跟踪
jstack -l <pid>打印指定进程 ID <pid> 的线程堆栈跟踪,包括锁信息
jstack -F <pid>强制打印指定进程 ID <pid> 的线程堆栈跟踪,即使进程可能不响应
jstack -m <pid>打印指定进程 ID <pid> 的线程堆栈跟踪,包括本地方法的堆栈信息

jstack主要用于生成JVM当前时刻的线程快照。线程快照是当前JVM内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等。除了可以使用jstack打印栈的信息,在代码层面也可以使用Thread.getAllStackTraces()方法获取堆栈信息。

jcmd

jcmd是一个功能强大的Java命令行工具,用于诊断和管理Java进程。它可以执行多种诊断命令、控制JVM的行为,并生成诊断报告。jcmd是JDK7及更高版本中引入的工具,能够替代许多其他诊断工具如jpsjstatjstack等,提供更加一致和全面的功能。

命令描述
jcmd <pid> VM.version显示指定进程 ID <pid> 的 JVM 版本信息
jcmd <pid> VM.flags显示指定进程 ID <pid> 的 JVM 启动参数
jcmd <pid> Thread.print打印指定进程 ID <pid> 的线程堆栈跟踪
jcmd <pid> GC.run执行垃圾回收并生成 GC 日志
jcmd <pid> GC.class_histogram打印指定进程 ID <pid> 的类实例直方图
jcmd <pid> JFR.start启动 Java Flight Recorder(JFR)数据采集
jcmd <pid> JFR.stop停止 JFR 数据采集并生成报告
jcmd <pid> JFR.dump导出 JFR 采集的数据
jcmd <pid> VM.system_properties显示指定进程 ID <pid> 的系统属性
jcmd <pid> VM.uptime显示指定进程 ID <pid> 的 JVM 启动时间

jconsole

jconsole是一个图形化的管理工具,提供了对Java进程的监控和管理功能。它是JDK附带的工具,基于Java Management Extensions实现。通过jconsole,用户可以实时监控JVM的性能、内存使用情况、线程状态等,并对应用程序进行管理和配置。这款工具的好处在于,占用系统资源少,而且结合jstat可以有效监控Java内存的变动情况,以及引起变动的原因。在项目追踪内存泄露问题时,很实用。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

分析工具

VisualVM

VisualVM是一个强大的Java应用程序性能分析工具,它提供了对JVM实例的监控、分析和管理功能。它包括内存分析、线程分析、垃圾回收监控、CPU使用情况分析以及堆转储分析等功能。它集成了多个JDK命令行工具,使用VisualVM可用于显示虚拟机进程及进程的配置和环境信息,监视应用程序的CPU、GC、堆、方法区及线程的信息等,甚至代替jconsole

常用功能:

  • 内存分析:查看堆内存使用情况,分析对象的分布和大小。
  • 线程分析:监控线程的活动和状态,捕捉线程堆栈快照。
  • CPU使用分析:分析应用程序的 CPU 使用情况,识别热点方法。
  • 堆转储分析:分析堆转储文件,帮助识别内存泄漏。
  • 垃圾回收监控:查看垃圾回收的统计数据和日志,帮助优化垃圾回收策略。

VisualVM支持插件扩展,可以在VisualVM上安装插件,也可以将VisualVM安装在IDEA上。

在这里插入图片描述
在这里插入图片描述

VisualVM可以生成dump文件,生成的dump文件是临时的,如果想要保留该文件需要右键另存为即可。

在这里插入图片描述

在这里插入图片描述

如果堆文件数据较大,排查起来很困难,可以使用OQL语句进行筛选。

OQL全称,Object Query Language类似于SQL查询的一种语言,OQL使用SQL语法,可以在堆中进行对象的筛选。
基本语法:

select <JavaScript expression to select> 
[ from (instanceof) <class name> <identifier>
( where <JavaScript boolean expression to filter> ) ]

1.class name是java类的完全限定名;
2.instanceof表示也查询某一个类的子类;
3.fromwhere子句都是可选的;
4.可以使用obj.field_name语法访问Java字段;

-- 查询长度大于等于100的字符串
select s from java.lang.String s where s.value.length >= 100-- 显示所有File对象的文件路径 
select file.path.value.toString() from java.io.File file-- 显示由给定id字符串标识的Class的实例
select o from instanceof 0x741012748 o

VisualVM也可以将两个dump文件进行比较。

在这里插入图片描述

VisualVM不但可以生成堆的dump文件,也可以对线程dump

在这里插入图片描述

Eclipse MAT

全称Eclipse Memory Analyzer Tool,是一个强大的Java内存分析工具,用于分析Java 堆转储文件。它帮助开发人员和运维人员识别和解决内存泄漏、内存占用过高等问题。MAT提供了多种分析功能,包括对象分布分析、泄漏查询、内存占用分析等。MAT是Eclipse开发的,不仅可以单独使用,还可以作为插件嵌入在Eclipse中使用。是一款免费的性能分析工具,使用起来很方便。

常用功能:

  • 内存泄漏检测:通过分析堆转储文件,识别可能的内存泄漏源。
  • 对象占用分析:查看特定对象或类的内存占用情况。
  • 引用链分析:分析对象之间的引用关系,帮助理解为什么对象无法被垃圾回收。
  • 查询功能:通过OQL(对象查询语言)执行自定义查询,分析堆数据。
  • 报告生成:生成详细的内存分析报告,提供对内存使用的深入洞察。

使用MAT分析dump文件,生成可疑泄漏报告。在生成可疑泄漏报告后,会在对应的堆转储文件目录下生成一个zip文件。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

MAT最主要的功能是分析dump文件,其中比较重要的功能就是直方图对象图。

在这里插入图片描述

  • 浅堆:一个对象结构所占用的大小,即对象头+实例数据+对齐填充,不包括内部引用对象大小;
  • 深堆:一个对象被 GC 回收后,可以真实释放的内存大小;
  • 对象的实际大小:一个对象所能触及的所有对象的浅堆大小之和;

举个例子

在这里插入图片描述

  • Object2浅堆大小:为Object2本身;
  • Object2深堆大小:Object2本身加上Object6,因为Object5Object1引用;
  • Object2实际大小:Object2本身加上Object6加上Object5

在MAT中,可以选择直方图视图来查看每个堆转储文件中的对象分布。通过对比不同时间点的堆转储,识别持续增长的对象数量,从而帮助发现内存泄漏。

在这里插入图片描述

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

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

相关文章

自动驾驶-预测概览

通过生成一条路径来预测一个物体的行为&#xff0c;在每一个时间段内&#xff0c;为每一辆汽车重新计算预测他们新生成的路径&#xff0c;这些预测路径为规划阶段做出决策提供了必要信息 预测路径有实时性的要求&#xff0c;预测模块能够学习新的行为。我们可以使用多源的数据…

超简单安装指定版本的clickhouse

超简单安装指定版本的clickhouse 命令执行shell脚本 idea连接 命令执行 参考官网 # 下载脚本 wget https://raw.githubusercontent.com/183461750/doc-record/d988dced891d70b23c153a3bbfecee67902a3757/middleware/data/clickhouse/clickhouse-install.sh # 执行安装脚本(中…

【漏洞复现】Netgear WN604 downloadFile.php 信息泄露漏洞(CVE-2024-6646)

0x01 产品简介 NETGEAR WN604是一款由NETGEAR&#xff08;网件&#xff09;公司生产的无线接入器&#xff08;或无线路由器&#xff09;提供Wi-Fi保护协议&#xff08;WPA2-PSK, WPA-PSK&#xff09;&#xff0c;以及有线等效加密&#xff08;WEP&#xff09;64位、128位和152…

亲测--linux下安装ffmpeg最新版本---详细教程

下载地址 Download FFmpeg 下载最新的https://ffmpeg.org/releases/ffmpeg-7.0.1.tar.xz 上传到服务器 解压 tar xvf ffmpeg-7.0.1.tar.xz 编译 cd ffmpeg-7.0.1 ./configure --prefix=/usr/local/ffmpeg make && make install 报错: 解决:在后面加 跳过检测…

【Word】——小技巧

1.PDF相关转换word PDF转换成Word在线转换器 - 免费 - CleverPDF 2. word插入公式 1.软件推荐&#xff08;免费&#xff09; 可直接将图片&#xff0c;截屏公式转为word标准规范形式 2.网址推荐 在线LaTeX公式编辑器-编辑器 &#xff08;每天有免费使次数&#xff09; 3.…

Matlab演示三维坐标系旋转

function showTwo3DCoordinateSystemsWithAngleDifference() clear all close all % 第一个三维坐标系 origin1 [0 0 0]; x_axis1 [1 0 0]; y_axis1 [0 1 0]; z_axis1 [0 0 1];% 绕 x 轴旋转 30 度的旋转矩阵 theta_x 30 * pi / 180; rotation_matrix_x [1 0 0; 0 cos(th…

Linux服务器配置Python+PyTorch+CUDA深度学习环境

参考博主 Linux服务器配置PythonPyTorchCUDA深度学习环境_linux cuda环境配置-CSDN博客 https://blog.csdn.net/NSJim/article/details/115386936?ops_request_misc&request_id&biz_id102&utm_termlinux%E8%99%9A%E6%8B%9F%E7%8E%AF%E5%A2%83%E6%8C%89pytorch%20…

4核16G服务器支持多少人?4C16G服务器性能测评

租赁4核16G服务器费用&#xff0c;目前4核16G服务器10M带宽配置70元1个月、210元3个月&#xff0c;那么能如何呢&#xff1f;配置为ECS经济型e实例4核16G、按固定带宽10Mbs、100GB ESSD Entry系统盘。 那么问题来了&#xff0c;4C16G10M带宽的云服务器可以支持多少人同时在线&…

C++ ───List的使用

目录 1.1 list的介绍 1.2 list的使用 1.2.1 list的构造 1.2.2 list iterator的使用 1.2.3 list capacity 1.2.4 list element access 1.2.5 list modifiers 1.2.6 list的迭代器失效 1.1 list的介绍 1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器&…

2024年汉字小达人比赛区级活动学校选拔的题型预测和真题示例

上一篇文章&#xff0c;好真题网为大家介绍了2024年上海市小学生汉字小达人比赛活动的轮次、举办日期、参赛对象、报名方式、费用和如何备考的建议等。 有家长朋友问汉字小达人考试的内容和范围是什么&#xff0c;有哪些题型&#xff0c;以及汉字小达人比赛和上海市小学生古诗…

PDF压缩软件电脑版 电脑pdf压缩怎么压缩文件

在数字化时代&#xff0c;pdf文件因其良好的兼容性和稳定性&#xff0c;已成为工作与生活中不可或缺的文件格式。然而&#xff0c;随着内容的增多&#xff0c;pdf文件的体积也随之增大&#xff0c;给文件的传输和存储带来了一定的困扰。本文将为你详细介绍如何在电脑上压缩pdf文…

关于Redis的最常见的十道面试题

面试题一&#xff1a;Redis为什么执行这么快&#xff1f; Redis运行比较快主要原因有以下几种&#xff1a; 纯内存操作&#xff1a;Redis将所有数据存储在内存中&#xff0c;这意味着对数据的读写操作直接在内存中运行&#xff0c;而内存的访问速度远远高于磁盘。这种设计使得…

LNMP架构部署及应用

部署LNMP架构流程 1.安装Nginx&#xff08;上传软件包&#xff0c;执行脚本&#xff09; yum -y install pcre-devel zlib-devel gcc gcc useradd -M -s /sbin/nologin nginx tar zxf nginx-1.12.0.tar.gz cd nginx-1.12.0 ./configure --prefix/usr/local/nginx --usernginx…

python原型链污染

python原型链污染 ​ 后面会有跟着Article_kelp慢慢操作的&#xff0c;前面先面向题目学习。 背景&#xff1a; ​ 国赛遇到了这个考点&#xff0c;然后之后的DASCTF夏季挑战赛也碰到了&#xff0c;抓紧粗略学一手&#xff0c;学了JavaScript之后再深究原型链污染。 简介&a…

传输层和网络层的关系,ip协议+ip地址+ip报头字段介绍(4位TOP字段,8位生存时间(ttl)),ip地址和端口号的作用

目录 传输层和网络层的关系 引入 介绍 ip协议 介绍 ip地址 引入 数据传递过程 举例(ip地址的作用) ip报头 格式 4位版本号 ip地址不足的问题 8位服务类型 4位TOP(type of service)字段 最小延时 最大吞吐量 4位首部长度 16位总长度 8位协议号 首部校验和…

《样式设计001:表单的2种提交方式》

描述&#xff1a;在开发小程序过程中&#xff0c;发现一些不错的案例&#xff0c;平时使用也比较多&#xff0c;稍微总结了下经验&#xff0c;以下内容可以直接复制使用&#xff0c;希望对大家有所帮助&#xff0c;废话不多说直接上干货&#xff01; 一&#xff1a;表单的2种…

【强化学习的数学原理】课程笔记--4(随机近似与随机梯度下降,时序差分方法)

目录 随机近似与随机梯度下降Mean estimationRobbins-Monro 算法用 Robbins-Monro 算法解释 Mean estimation用 Robbins-Monro 算法解释 Batch Gradient descent用 SGD 解释 Mean estimation SGD 的一个有趣的性质 时序差分方法Sarsa 算法一个例子 Expected Sarsa 算法n-step S…

电容认识和特点总结

图片 常见的电容名字及特点 名字特点容量和耐压独石电容MLCCMulti layer Ceramic Capacitors (多层陶瓷电容) 常见的贴片电容&#xff0c;容量大于瓷片电容0.5pF~100uF,耐压<100V瓷片/陶瓷电容耐压远高于独石电容,容量小<0.1uf&#xff0c;用于晶振旁路电容滤波铝电解电…

PY32F002B单片机 ISP 串口下载注意事项

一、PY32F002B ISP 串口下载的连接方式 仿真上的 VCC 和 GND 连接到 MCU 的 VCC 和 VSS&#xff0c; 仿真的 TX 接 MCU 的 RX&#xff0c;RX 接 MCU 的 TX。 二、因为 PY32F002B 没有 BOOT&#xff0c;需要用 ISP 串口下载的话需要下载串口引导程序。 下载这个目录下的 IAP…

Python酷库之旅-第三方库Pandas(036)

目录 一、用法精讲 111、pandas.Series.item方法 111-1、语法 111-2、参数 111-3、功能 111-4、返回值 111-5、说明 111-6、用法 111-6-1、数据准备 111-6-2、代码示例 111-6-3、结果输出 112、pandas.Series.xs方法 112-1、语法 112-2、参数 112-3、功能 112-…