首先是获取当前Java运行的Java进程ID,这个是网上常见的,也就是Java程序自身将进程ID打印出来:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
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();
}
}
|
运行结果:
1
2
|
2896@PC-20150603VRPL
2896
|
ManagementFactory是一个在运行时管理和监控Java VM的工厂类,它能提供很多管理VM的静态接口,比RuntimeMXBean;
RuntimeMXBean是Java虚拟机的运行时管理接口.
当前进程ID为2896。
但这种让Java进程自行打印ID的方式并不太好用,因为很多时候我们是需要在不修改代码另一个Java程序代码的情况下知道这个正在运行着的Java进程的ID,如果你也有这个需求,可以看一下下面的解决方法:
获取所有正在运行着的Java进程
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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);
}
}
}
|
运行结果:
1
2
3
|
2752 ------>
5172 ------> com.test.Target
5308 ------> com.test.ProcessID
|
这样,就可以根据类名找到进程号了。
MonitoredHost等类位于${JAVA_HOME}/lib/tools.jar
下面是一个可以直接根据类找到对应Java进程ID的方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
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 ;
}
}
|
运行结果:
PID: 5172
源码位于我的Github项目aoptracer的com.test包里
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/zgljl2012/article/details/50989976