用java监视系统进程的两个解决方案
2007-07-22 16:30
302 查看
用第一个java虚拟机启动另一个虚拟机,并用第一个虚拟机的java程序去测试另一个虚拟机上java程序运行时的内存,CPU资源占用情况。
解决问题的限制和条件:
1》两个虚拟机运行在同台Windows_X86机上。
2》只需要知道第二个虚拟机上运行程序时,第二个虚拟机的内存、CPU使用情况。
3》目的是:测试不同的程序在同个虚拟机上资源使用差别。
解决问题的关键:
第一 如何启动另一虚拟机运行测试的java程序。
第二 如何用第一个虚拟机里的java程序,监视另一个虚拟机与其相关进程的运行情况。
解决办法:
一、使用java.io中的函数(命令试过没问题,程序请按下面提示完成)
使用java.io中的函数
Runtime.getRuntime()。exec("系统命令");
这里我给一个带命令参数的例子
这里要使用到的系统命令有几个:
这两步均在第一个虚拟机完成,简单!!!
二、常规方法使用JNI
这里我给一套解决方案,网上有很多相关代码,自己去找找;
这套方案也可以实现,这里我使用简单的实现方法用C#来做监控,但这这个方案明显有其不足之处;就是测试对象的JNI接口会被触发,当然,如果不要求数据的准确性,单从比较的角度去看,只要运行的没有本身没有使用到JNI这个方案还是可行的。
解决问题的限制和条件:
1》两个虚拟机运行在同台Windows_X86机上。
2》只需要知道第二个虚拟机上运行程序时,第二个虚拟机的内存、CPU使用情况。
3》目的是:测试不同的程序在同个虚拟机上资源使用差别。
解决问题的关键:
第一 如何启动另一虚拟机运行测试的java程序。
第二 如何用第一个虚拟机里的java程序,监视另一个虚拟机与其相关进程的运行情况。
解决办法:
一、使用java.io中的函数(命令试过没问题,程序请按下面提示完成)
使用java.io中的函数
Runtime.getRuntime()。exec("系统命令");
这里我给一个带命令参数的例子
Runtime r=Runtime.getRuntime(); Process p=null; String cmd[]={"命令","参数"}; try{ p=r.exec(cmd); } catch(Exception e){ System.out.println("error executing: "+cmd[0]); } |
path/java file //用第二个jvm(path为第二个jre/bin/地址)运行java程序file tasklist > log.txt //将当前系统进程写以“任务管理器”的格式()写入 //log.txt文件中,关于tasklist使用细节,如查询某个进程ID的信息 //可以使用命令 >tasklist /? 进行查询 |
二、常规方法使用JNI
这里我给一套解决方案,网上有很多相关代码,自己去找找;
这套方案也可以实现,这里我使用简单的实现方法用C#来做监控,但这这个方案明显有其不足之处;就是测试对象的JNI接口会被触发,当然,如果不要求数据的准确性,单从比较的角度去看,只要运行的没有本身没有使用到JNI这个方案还是可行的。
相关文章推荐
- 用java监视系统进程的两个解决方案
- JAVA 监视Windows系统的进程代码
- java系统高并发解决方案之图片服务器分离
- java系统高并发解决方案之图片服务器分离
- java模拟系统进程算法的小程序
- java系统高并发解决方案
- java系统高并发解决方案(转载)
- java监视系统内存状态小程序
- java系统高并发解决方案
- JAVA系统下的FLASH,FLV视频应用解决方案
- java系统高并发解决方案
- java系统高并发解决方案
- java系统高并发解决方案之图片服务器分离
- java获得windows系统时间有误的解决方案
- 监视系统进程,防止病毒假冒,用路径的方式来判断
- java系统高并发的解决方案
- java系统高并发的解决方案
- java如何监控系统进程和服务的状态
- 内存分配的原理__进程分配内存有两种方式,分别由两个系统调用完成:brk和mmap(不考虑共享内存)
- java开发系统内核:实现进程自动切换,再现Linus当年辉煌一刻