Java获取当前进程ID以及所有Java进程的进程ID

2018-01-18 10:16:33

首先是获取当前Java运行的Java进程ID,这个是网上常见的,也就是Java程序自身将进程ID打印出来:

package com.test;import java.lang.management.ManagementFactory;import java.lang.management.RuntimeMXBean;public class Target {

    public static void main(String[] args) throws InterruptedException {
        System.out.println(getProcessID());        while(true) {
            Thread.sleep(10000);
        }
    }    public static final int getProcessID() {  
        RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();
        System.out.println(runtimeMXBean.getName());        return Integer.valueOf(runtimeMXBean.getName().split("@")[0])  
                .intValue();  
    } 

}1234567891011121314151617181920212223

运行结果:

2896@PC-20150603VRPL289612

ManagementFactory是一个在运行时管理和监控Java VM的工厂类,它能提供很多管理VM的静态接口,比如RuntimeMXBean

RuntimeMXBean是Java虚拟机的运行时管理接口.

当前进程ID为2896。

但这种让Java进程自行打印ID的方式并不太好用,因为很多时候我们是需要在不修改代码另一个Java程序代码的情况下知道这个正在运行着的Java进程的ID,如果你也有这个需求,可以看一下下面的解决方法:

获取所有正在运行着的Java进程

package com.test;import java.util.HashSet;import java.util.Set;import sun.jvmstat.monitor.MonitoredHost;import sun.jvmstat.monitor.MonitoredVm;import sun.jvmstat.monitor.MonitoredVmUtil;import sun.jvmstat.monitor.VmIdentifier;public class ProcessID {

    public static void main(String[] args) throws Exception {         // 获取监控主机
         MonitoredHost local = MonitoredHost.getMonitoredHost("localhost");         // 取得所有在活动的虚拟机集合
         Set<?> vmlist = new HashSet<Object>(local.activeVms());         // 遍历集合,输出PID和进程名
         for(Object process : vmlist) {
             MonitoredVm vm = local.getMonitoredVm(new VmIdentifier("//" + process));             // 获取类名
             String processname = MonitoredVmUtil.mainClass(vm, true);
             System.out.println(process + " ------> " + processname);
         }
     }
}123456789101112131415161718192021222324252627

运行结果:

2752 ------> 
5172 ------> com.test.Target5308 ------> com.test.ProcessID123

这样,就可以根据类名找到进程号了。

MonitoredHost等类位于${JAVA_HOME}/lib/tools.jar

下面是一个可以直接根据类找到对应Java进程ID的方法:

package com.test;import java.net.URISyntaxException;import java.util.HashSet;import java.util.Set;import sun.jvmstat.monitor.MonitorException;import sun.jvmstat.monitor.MonitoredHost;import sun.jvmstat.monitor.MonitoredVm;import sun.jvmstat.monitor.MonitoredVmUtil;import sun.jvmstat.monitor.VmIdentifier;public class ProcessID {

    public static void main(String[] args) throws Exception {         int pid = getProcess(Target.class);
         System.out.println("PID: "+pid);
    }    public static int getProcess(Class<?> cls) throws MonitorException, URISyntaxException {        if(cls == null) {            return -1;
        }        // 获取监控主机
        MonitoredHost local = MonitoredHost.getMonitoredHost("localhost");        // 取得所有在活动的虚拟机集合
        Set<?> vmlist = new HashSet<Object>(local.activeVms());        // 遍历集合,输出PID和进程名
        for(Object process : vmlist) {
            MonitoredVm vm = local.getMonitoredVm(new VmIdentifier("//" + process));            // 获取类名
            String processname = MonitoredVmUtil.mainClass(vm, true);            if(cls.getName().equals(processname)) {                return ((Integer)process).intValue();
            }
        }        return -1;
    }
}1234567891011121314151617181920212223242526272829303132333435363738394041

运行结果:

PID: 51721

源码位于我的Github项目aoptracer的com.test包里


  • 2020-01-30 11:19:58

    Android中添加两个(多个)FileProvider节点问题

    我们知道在android7.0,修改了对私有存储的限制,导致在获取资源的时候,不能通过Uri.fromFile(..)来获取uri了,但是在写入数据的时候是可以通过Uri.fromFile(..)来获取uri的,android 官网给出的解决办法是通过FileProvider来解决这一问题,我们需要在AndroidManifest.xml 配制provider节点。

  • 2020-02-02 15:40:36

    Apache Commons IO之IOUtils优雅操作流

    在开发过程中,你肯定遇到过从流中解析数据,或者把数据写入流中,或者输入流转换为输出流,而且最后还要进行流的关闭,原始jdk自带的方法写起来太复杂,还要注意各种异常,如果你为此感到烦恼,那IOUtils可以让我们优雅的操作流。

  • 2020-02-02 19:24:38

    百度视频SDK,突然不能播放

    开发过程中,不知道什么时候开始视频不能播发了,怎么办都不行,其他项目没问题,线上都也没有问题,这可急躁完蛋我了,整了仨小时,还是那熊样。 哎。

  • 2020-02-04 18:43:10

    AssetManager.finalize() Timed Out 解决办法以及分析

    在我们的项目崩溃中,有一个比较常见的bug,就是 java.util.concurrent.TimeoutException android.content.res.AssetManager.finalize() timed out after 10 seconds 意思简单明了,就是说在AssetManager析构的时候发生了超时异常。