深入了解Java JPS

Java JPS (Java虚拟机进程状态工具) 是Java JDK中的一个命令行工具,用于查看Java进程的状态信息。本文将从多个方面对Java JPS进行详细阐述。

一、JPS的基本用法

JPS可用于查看当前运行的Java进程信息。在命令行中输入“jps”即可查看当前运行的所有Java进程PID和进程名。

$ jps
1234 Main
5678 Tomcat
8910 Jps

其中,PID表示进程ID,进程名为启动Java进程时所指定的主类的名称。

如果要查看指定Java进程的PID,可以通过“-l”参数查看完整的进程名,然后通过grep命令过滤:

$ jps -l |grep Main
1234 Main

除了“-l”参数之外,JPS还支持其他常用的参数:

  • -m:显示进程中启动主类时的参数
  • -v:显示进程中启动主类时的JVM参数
  • -q:只输出PID

二、使用JPS定位Java进程的问题

JPS除了可以查看Java进程的状态信息,还可以用于定位Java进程的问题。以下是几种常见的问题:

1. Java进程OOM

如果Java进程遇到OOM (内存溢出)问题,可以通过JPS查看对应的进程ID,并查看内存情况。

$ jps
1234 Main
$ jstat -gcutil 1234
 S0    S1     E     O     P     YGC     YGCT    FGC    FGCT     GCT
 0.00  85.19  73.00  86.50  68.63   349    4.131  11     0.705    4.836

jstat命令用于监视Java虚拟机的各种运行状态,例如垃圾回收情况。以上命令将输出对应进程的堆内存状态。从中可以看到目前堆内存已经使用了86.50%。

2. Java进程卡死

如果Java进程卡死,可以使用JPS查看对应的进程ID,并使用jstack命令查看堆栈信息。使用jstack命令可以查看Java进程的堆栈信息,定位卡死的程序段。

$ jps
1234 Main
$ jstack 1234

三、JPS与Java Management Extensions (JMX)

Java Management Extensions (JMX) 是一种Java平台管理系统。JMX提供了一组标准API用于管理和监视Java应用程序,可以实现对应用程序的监控、控制和管理。

JPS与JMX结合使用可以监听Java进程的状态信息,包括内存、线程、GC情况等。使用JConsole (Java GUI监测工具) 和jvisualvm (Java VisualVM工具) 可以以图形化界面的形式展示各种指标。以下是几个常用的命令:

  • jstatd:启动jstat监测服务
  • jconsole:启动Java GUI监测工具
  • jvisualvm:启动Java VisualVM工具

四、JPS命令的实际应用

JPS命令可以用于实际开发中的各种场景。以下是几个例子:

1. 检查Java进程是否启动

在自动化测试和运维中,我们需要检查Java进程是否正常启动。可以使用JPS命令来检查Java进程是否正常运行。

private boolean checkProcessRunning(String processName) {
    String line;
    String pidAndName;
    try {
        Process p = Runtime.getRuntime().exec("jps -l");
        try (BufferedReader input = new BufferedReader(new InputStreamReader(p.getInputStream()))) {
            while ((line = input.readLine()) != null) {
                pidAndName = line.trim();
                if (pidAndName.endsWith(processName)) {
                    return true;
                }
            }
        }
    } catch (Exception err) {
        err.printStackTrace();
    }
    return false;
}

2. 获取Java进程信息

在应用程序中需要获取Java进程的状态信息,例如进程ID、内存、线程、GC情况等。可以使用JPS命令结合JMX API来获取Java进程的状态信息。

public class JvmInfo {
    private static MBeanServerConnection getMBeanServerConnection(int pid) throws IOException {
        JMXServiceURL serviceURL = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:" + getRegistryPort(pid) + "/jmxrmi");
        JMXConnector jmxConnector = JMXConnectorFactory.connect(serviceURL);
        return jmxConnector.getMBeanServerConnection();
    }

    private static int getRegistryPort(int pid) throws IOException {
        String command = String.format("service:jmx:rmi:///jndi/rmi://localhost:%d/jmxrmi", findRmiRegistryPort(pid));
        JMXServiceURL jmxUrl = new JMXServiceURL(command);
        JMXConnector jmxConnector = JMXConnectorFactory.connect(jmxUrl, null);
        return jmxConnector.getServerConnection().getAddress().getPort();
    }

    private static int findRmiRegistryPort(int pid) throws IOException {
        String pidString = String.valueOf(pid);
        String[] cmd = { "jps", "-v" };
        Process p = Runtime.getRuntime().exec(cmd);
        BufferedReader input = new BufferedReader(new InputStreamReader(p.getInputStream()));
        String line = null;
        while ((line = input.readLine()) != null) {
            if (line.contains(pidString)) {
                return Integer.valueOf(line.split("-Dcom.sun.management.jmxremote.port=")[1].split("\\s+")[0]);
            }
        }
        return 0;
    }

    public static void printJvmInfo(int pid) throws IOException {
        MBeanServerConnection conn = getMBeanServerConnection(pid);
        MemoryMXBean memoryMXBean = ManagementFactory.newPlatformMXBeanProxy(conn, ManagementFactory.MEMORY_MXBEAN_NAME, MemoryMXBean.class);
        System.out.println("heap memory usage : " + memoryMXBean.getHeapMemoryUsage());
        System.out.println("non-heap memory usage : " + memoryMXBean.getNonHeapMemoryUsage());
        ThreadMXBean threadMXBean = ManagementFactory.newPlatformMXBeanProxy(conn, ManagementFactory.THREAD_MXBEAN_NAME, ThreadMXBean.class);
        System.out.println("thread count : " + threadMXBean.getThreadCount());
        System.out.println("GC count : " + memoryMXBean.getCollectionCount());
        for (GarbageCollectorMXBean gcMbean : ManagementFactory.getGarbageCollectorMXBeans()) {
            System.out.println(gcMbean.getName() + " GC count : " + gcMbean.getCollectionCount());
        }
    }
}

结论

本文中详细阐述了Java JPS的基本用法、与Java进程问题的定位、与JMX的结合使用和实际应用。通过JPS命令,可以更好地监测和管理Java应用程序。

原创文章,作者:PZPUG,如若转载,请注明出处:https://www.506064.com/n/333415.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
PZPUGPZPUG
上一篇 2025-02-01 13:34
下一篇 2025-02-01 13:34

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29
  • Java 8 Group By 会影响排序吗?

    是的,Java 8中的Group By会对排序产生影响。本文将从多个方面探讨Group By对排序的影响。 一、Group By的概述 Group By是SQL中的一种常见操作,它…

    编程 2025-04-29

发表回复

登录后才能评论