利用java程序检查服务器或主机的运行时信息,包括操作系统、CPU使用情况、内存使用情况、硬盘使用情况以及网卡、网络信息。主要的办法有两 种:第一种,使用jdk1.6以上自动的功能,实现数据的获取,但是该方法局限性较大,而且获得的数据也比较少,尤其是内存信息不够准确。所以,在此不讨 论该方法。第二种,使用第三方的jar包进行获取,通过直接调用操作系统的api来获取系统相关数据。
本文则主要介绍一种通过Hyperic- hq产品的基础包sigar.jar来实现服务器状态数据的获取。Sigar.jar包是通过本地方法来调用操作系统API来获取系统相关数据。
实时监测服务器主机的物理信息,如CPU使用信息、内存使用信息、硬盘使用信息以及网卡和网络的使用情况。
com.system.runtime |-common | |-SystemRuntime.java | 操作实体类 |-pojo | |-systemStatusPojo.java | 存储系统实时状态的po |-service | |-systemStatusService.java | | RMI服务接口 | |-systemStatusServiceImpl.java | 服务的实现 |-main.java 主函数入口 demo |-sigar.java 官方示例 test |-Client.java 客户端测试 jar 生成的可以用jar包 lib 官方jar包以及底层支撑文件
Mac下,eclipse中的配置方法:项目右键->属性->java build path->选择Libraries中的sigar.jar->在展开的Native library location中选择底层文件所在目录即可
jar包中不提供网络传输速率的方法,需要采集两次,自行计算出传输速率
在网络传输中,当有多个网卡进行切换时,rmi会出现无法连接的错误。建议更换IP地址访问。
如:服务器处于两个局域网 192.168.191. 和 172.29.131. ,客户端处于 192.168.191. 之中。当客户端连接192.168.191. 时可用连接,但是响应超时。但是连接 172.29.131.* 时则可以正常使用