首页 > 其他分享 >JVM调优 jstat 与 jstack

JVM调优 jstat 与 jstack

时间:2024-07-21 18:29:20浏览次数:14  
标签:Java java jstack 信息 调优 线程 jstat

jstat

jstat 是一个命令行工具,用于监控正在运行的 Java 虚拟机(JVM)的性能。它能够显示关于堆内存、非堆内存、类加载、编译器活动、垃圾收集器(GC)活动等各种运行时数据的信息。jstat 是 JDK 自带的工具之一,无需额外安装。

要使用 jstat 监控 JVM 的内存和 GC 情况,你可以按照以下步骤操作:

启动 JVM

首先,你需要启动一个 Java 应用程序,确保你知道该应用程序的进程 ID(PID)。你可以通过 jps 命令找到正在运行的 Java 进程。

使用 jstat

基本语法
jstat [option] [interval] [vmid]
  • option:指定要收集哪种类型的数据。
  • interval:采样间隔(毫秒),如果省略则只输出一次。
  • vmid:虚拟机的进程 ID。
常用选项
  • -gc:显示有关垃圾收集的统计信息。
  • -gccapacity:显示堆和非堆内存容量信息。
  • -gcutil:显示垃圾收集的百分比利用率。
  • -class:显示类加载统计信息。
  • -compiler:显示编译器统计信息。
示例
  • 查看 JVM 的 GC 统计信息:

    jstat -gc 12345
    

    其中 12345 是你的 Java 进程的 PID。

  • 定时查看 GC 统计信息,每 1 秒钟一次:

    jstat -gc 1000 12345
    
  • 查看堆内存和 GC 利用率:

    jstat -gcutil 12345
    
输出解释

当你使用 -gc-gcutil 等选项时,jstat 将输出一列数据,每一列代表了 JVM 的不同部分或活动。例如:

  • S0CS1C:表示幸存者空间 0 和幸存者空间 1 的容量。
  • S0US1U:表示幸存者空间 0 和幸存者空间 1 的使用量。
  • EC:表示 Eden 区的容量。
  • EU:表示 Eden 区的使用量。
  • OC:表示老年代的容量。
  • OU:表示老年代的使用量。
  • MC:表示元空间的容量(在 JDK 9 及更高版本中)。
  • MU:表示元空间的使用量(在 JDK 9 及更高版本中)。
  • CCSC:表示压缩类空间的容量(在 JDK 9 及更高版本中)。
  • CCSU:表示压缩类空间的使用量(在 JDK 9 及更高版本中)。
  • YGC:表示年轻代垃圾收集次数。
  • YGCT:表示年轻代垃圾收集总时间。
  • FGC:表示完全垃圾收集次数。
  • FGCT:表示完全垃圾收集总时间。
  • GCT:表示垃圾收集总时间。

理解这些指标可以帮助你诊断 JVM 的性能问题,比如频繁的垃圾收集或内存泄漏。


jstack

jstack 是一个 Java 工具,用于生成 Java 进程的线程快照。它能帮助你诊断挂起(hang)或响应慢的应用程序,通过展示每个线程的堆栈跟踪信息,可以分析线程的状态以及它们在做什么。这对于理解线程间交互、死锁情况、长时间运行的请求等问题非常有用。

使用 jstack

基本语法
jstack [options] <pid>
  • <pid> 是 Java 进程的 ID。
  • [options] 可以是多个可选参数,用来控制输出的格式或显示的信息。
常见选项
  • -l--long:产生详细的堆栈跟踪信息,包括锁信息和监视器信息。
  • -F--file:当通过 PID 无法访问 Java 进程时,可以指定 core 文件或转储文件作为输入。
  • -m--mixed:显示混合模式堆栈,即 Java 和本地方法的堆栈跟踪。
  • -h--help:显示帮助信息。

如何使用

  1. 查找 Java 进程的 PID
    首先,你需要确定 Java 进程的 PID。你可以使用 jps 命令来列出所有正在运行的 Java 进程。

  2. 生成线程堆栈信息
    执行 jstack 命令,将找到的 PID 作为参数传递给它。

    例如:

    jstack 1234 > stacktrace.txt
    

    这里 1234 是你的 Java 进程的 PID。> stacktrace.txt 将输出重定向到一个文本文件,便于后续分析。

  3. 分析输出
    jstack 输出将包含每个线程的堆栈跟踪,包括线程 ID、线程名称、线程状态以及调用栈。通过分析这些信息,你可以判断哪些线程处于阻塞状态、哪些线程持有锁、哪些线程可能造成死锁等。

输出解读

jstack 的输出通常会显示如下信息:

  • 线程 ID 和名称
  • 线程状态(如 RUNNABLE, BLOCKED, WAITING 等)
  • Java 方法调用栈
  • 锁信息(如果使用了 -l 参数)

例如,你可能会看到类似这样的输出:

"main" #1 prio=5 os_prio=0 tid=0x00007f6b47fff800 nid=0x3500 waiting on condition [0x00007f6b47f8c000]
   java.lang.Thread.State: WAITING (parking)
        at sun.misc.Unsafe.park(Native Method)
        - parking to wait for  <0x00000007a29e6488> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
        at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
        at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)
        at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)
        at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1067)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1127)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)

通过这些信息,你可以识别出线程在哪个方法上被阻塞,或者是否在等待某种条件,从而定位问题所在。

标签:Java,java,jstack,信息,调优,线程,jstat
From: https://blog.csdn.net/Casual_Lei/article/details/140591245

相关文章

  • 数据库的性能调优:如何正确的使用索引?
    在当今的数据驱动时代,数据库的性能优化成为每个开发者和数据库管理员必须掌握的技能之一。而在众多优化手段中,索引的使用无疑是最为重要和有效的。然而,索引的滥用或误用不仅不会提升性能,反而可能带来额外的开销。那么,如何正确地使用索引,才能真正提升数据库性能呢?为什么有时我们......
  • Java中的内存管理与调优策略
    Java中的内存管理与调优策略大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!今天我们将深入探讨Java中的内存管理与调优策略。Java的内存管理涉及多个方面,包括垃圾回收、堆和非堆内存的配置,以及性能优化。通过这些策略,我们可以显著提高应用程序的性能和稳......
  • 101文章解读与程序——中国电机工程学报EI\CSCD\北大核心《考虑气电联合需求响应的
    ......
  • 万字总结LightGBM原理、核心参数以及调优思路(上篇)
    万字总结LightGBM原理、核心参数以及调优思路(上篇)在机器学习领域,LightGBM凭借其卓越的速度和准确性,迅速成为众多数据科学家和算法工程师的首选算法之一。作为一款基于梯度提升框架的高效机器学习工具,LightGBM在处理大规模数据集时表现出色,尤其适用于需要快速模型训练和预测......
  • 数据分享|R语言决策树和随机森林分类电信公司用户流失churn数据和参数调优、ROC曲线可
    原文链接:http://tecdat.cn/?p=26868最近我们被客户要求撰写关于电信公司用户流失的研究报告,包括一些图形和统计输出。在本教程中,我们将学习覆盖决策树和随机森林。这些是可用于分类或回归的监督学习算法下面的代码将加载本教程所需的包和数据集。  library(tidyverse)......
  • JVM调优参数和概念
    Java虚拟机(JVM)调优是一个复杂的过程,涉及到对JVM的内存管理、垃圾收集器选择、线程管理等多个方面的优化。以下是一些常见的JVM调优参数和概念:1.**堆内存设置**:  -`-Xms<size>`:设置JVM启动时的初始堆大小。  -`-Xmx<size>`:设置JVM最大堆大小。2.**新生代和老年代......
  • elasticsearch性能调优方法原理与实战
    ❃博主首页:「码到三十五」,同名公众号:「码到三十五」,wx号:「liwu0213」☠博主专栏:<mysql高手><elasticsearch高手><源码解读><java核心><面试攻关>♝博主的话:搬的每块砖,皆为峰峦之基;公众号搜索「码到三十五」关注这个爱发技术干货的coder,......
  • 万字总结XGBoost原理、核心参数以及调优思路(下篇)
    万字总结XGBoost原理、核心参数以及调优思路(下篇)在数据科学领域,XGBoost以其卓越的性能和灵活性,成为了众多机器学习算法中的佼佼者。作为一种梯度提升框架,XGBoost通过构建决策树的集合来最小化一个可微分的损失函数,广泛应用于分类、回归等任务。本文将万字总结XGBoost的深层......
  • Linux 系统调优之安全防护1
    文章目录前言1、系统命令审计2、公网防护3、服务器使用秘钥登录4、默认账户及口令文件的防护5、其他配置总结前言  Linux系统以其开放性和强大的功能成为众多企业和开发者的首选。然而,开放性也带来了安全风险。本文将探讨Linux系统调优中的安全防护策略,分享并......
  • Linux 系统调优之安全防护2
    文章目录1、限制NFS访问2、禁止icmp报文响应3、更改ssh访问端口4、添加GRUB菜单密码5、用户系统资源限制总结  大家好,我是技术界的小萌新,今天要和大家分享一些干货。在阅读之前请先点赞......