jstack(查看线程)、jmap(查看内存)和jstat(性能分析)

本文介绍了如何使用jstack、jmap和jstat命令进行Java性能分析。通过jstack查看线程状态,jmap检查内存使用情况,jstat监控应用程序性能。内容包括获取线程数、查看堆内存分配、强制垃圾回收、生成堆dump文件等操作,旨在帮助开发者定位和解决性能问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jstack(查看线程)、jmap(查看内存)和jstat(性能分析)

1.使用top,查询出最耗内存的cpu对应的pid

/opt/java8/bin/jstack
 
Usage:
    jstack [-l] <pid>   举例:jstack -l 8748
        (to connect to running process) 连接活动线程
    jstack -F [-m] [-l] <pid>
        (to connect to a hung process) 连接阻塞线程
    jstack [-m] [-l] <executable> <core>
        (to connect to a core file) 连接dump的文件
    jstack [-m] [-l] [server_id@]<remote server IP or hostname>
        (to connect to a remote debug server) 连接远程服务器
 
Options:
    -F  to force a thread dump. Use when jstack <pid> does not respond (process is hung)
    -m  to print both java and native frames (mixed mode)
    -l  long listing. Prints additional information about locks
    -h or -help to print this help message

2.查询pid下有多少个线程:jstack -l pid | grep 'java.lang.Thread.State' | wc -l    显示 'java.lang.Thread.State'的行数

举例:jstack -l 8748  | grep 'java.lang.Thread.State' | wc -l   --->返回线程数 266

3.把jstack记录保存到文件里 :

cd  /log/java/push-service

jstack -l pid >> 123.txt , rz 上传命令,sz 123.txt 下载命令

jstack 12652 | head -100

4.查看当前进程消耗资源的线程pid top -Hp pid

5 将线程Pid转为16进制,根据该16进制值去打印的堆栈日志内查询,查看该线程所驻留的方法位置。
 

printf "%x\n" 17880          
45d8
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值