Java如何实现系统监控、系统信息收集(转
Java如何实现系统监控、系统信息收集、sigar开源API的学习
系统监控(1)
Jar资源下载:http://download.csdn.net/detail/yixiaoping/4903853
首先给大家介绍一个开源工具Sigar
官网:http://sigar.hyperic.com/
API: http://www.hyperic.com/support/docs/sigar/index-all.html(由于是英文的,英文不好的可以用谷歌浏览器的翻译功能,直接转换为简体中文进行阅读)
Sigar(System Information Gatherer And Reporter),是一个开源的工具,提供了跨平台的系统信息收集的API,由C语言实现的。可以收集的信息包括:
1, CPU信息,包括基本信息(vendor、model、mhz、cacheSize)和统计信息(user、sys、idle、nice、wait)
2, 文件系统信息,包括Filesystem、Size、Used、Avail、Use%、Type
3, 事件信息,类似Service Control Manager
4, 内存信息,物理内存和交换内存的总数、使用数、剩余数;RAM的大小
5, 网络信息,包括网络接口信息和网络路由信息
6, 进程信息,包括每个进程的内存、CPU占用数、状态、参数、句柄
7, IO信息,包括IO的状态,读写大小等
8, 服务状态信息
9, 系统信息,包括操作系统版本,系统资源限制情况,系统运行时间以及负载,Java的版本信息等.
Sigar在Java中的使用:
开发时将附件中sigar.rar中的所有文件及jar包放在工程的lib文件夹下。
Java代码
package com.test_sigar;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.text.DecimalFormat;
import org.hyperic.sigar.CpuInfo;
import org.hyperic.sigar.CpuPerc;
import org.hyperic.sigar.FileSystem;
import org.hyperic.sigar.FileSystemUsage;
import org.hyperic.sigar.Mem;
import org.hyperic.sigar.NetFlags;
import org.hyperic.sigar.NetInterfaceConfig;
import org.hyperic.sigar.NetInterfaceStat;
import org.hyperic.sigar.OperatingSystem;
import org.hyperic.sigar.Sigar;
import org.hyperic.sigar.SigarException;
import org.hyperic.sigar.SigarNotImplementedException;
import org.hyperic.sigar.Swap;
public class SysInfo {
public static void main(String [] args) throws Exception{
SysInfo s =new SysInfo();
System.out.println("CPU个数:"+s.getCpuCount());
s.getCpuTotal();
s.testCpuPerc();
s.getPhysicalMemory();
s.testWho();
s.testFileSystemInfo();
s.testGetOSInfo();
}
/**
* 1.CPU资源信息
*/
// a)CPU数量(单位:个)
public static int getCpuCount() throws SigarException {
Sigar sigar = new Sigar();
try {
return sigar.getCpuInfoList().length;
} finally {
sigar.close();
}
}
// b)CPU的总量(单位:HZ)及CPU的相关信息
public void getCpuTotal() {
Sigar sigar = new Sigar();
CpuInfo[] infos;
try {
infos = sigar.getCpuInfoList();
for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用
CpuInfo info = infos[i];
System.out.println("CPU的总量:" + info.getMhz());// CPU的总量MHz
System.out.println("获得CPU的卖主:" + info.getVendor());// 获得CPU的卖主,如:Intel
System.out.println("CPU的类别:" + info.getModel());// 获得CPU的类别,如:Celeron
System.out.println("缓冲存储器数量:" + info.getCacheSize());// 缓冲存储器数量
System.out.println("**************");
}
} catch (SigarException e) {
e.printStackTrace();
}
}
// c)CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%)
public void testCpuPerc() {
Sigar sigar = new Sigar();
// 方式一,主要是针对一块CPU的情况
CpuPerc cpu;
try {
cpu = sigar.getCpuPerc();
printCpuPerc(cpu);
} catch (SigarException e) {
e.printStackTrace();
}
// 方式二,不管是单块CPU还是多CPU都适用
CpuPerc cpuList[] = null;
try {
cpuList = sigar.getCpuPercList();
} catch (SigarException e) {
e.printStackTrace();
return;
}
for (int i = 0; i < cpuList.length; i++) {
printCpuPerc(cpuList[i]);
}
}
private void printCpuPerc(CpuPerc cpu) {
System.out.println("用户使用率:" + CpuPerc.format(cpu.getUser()));// 用户使用率
System.out.println("系统使用率:" + CpuPerc.format(cpu.getSys()));// 系统使用率
System.out.println("当前等待率:" + CpuPerc.format(cpu.getWait()));// 当前等待率
System.out.println("Nice :" + CpuPerc.format(cpu.getNice()));//
System.out.println("当前空闲率:" + CpuPerc.format(cpu.getIdle()));// 当前空闲率
System.out.println("总的使用率:" + CpuPerc.format(cpu.getCombined()));// 总的使用率
System.out.println("**************");
}
/**
* 2.内存资源信息
*
*/
public void getPhysicalMemory() {
// a)物理内存信息
DecimalFormat df = new DecimalFormat("#0.00");
Sigar sigar = new Sigar();
Mem mem;
try {
mem = sigar.getMem();
// 内存总量
System.out.println("内存总量:" + df.format((float)mem.getTotal() / 1024/1024/1024) + "G");
// 当前内存使用量
System.out.println("当前内存使用量:" + df.format((float)mem.getUsed() / 1024/1024/1024) + "G");
// 当前内存剩余量
System.out.println("当前内存剩余量:" + df.format((float)mem.getFree() / 1024/1024/1024) + "G");
// b)系统页面文件交换区信息
Swap swap = sigar.getSwap();
// 交换区总量
System.out.println("交换区总量:" + df.format((float)swap.getTotal() / 1024/1024/1024) + "G");
// 当前交换区使用量
System.out.println("当前交换区使用量:" + df.format((float)swap.getUsed() / 1024/1024/1024) + "G");
// 当前交换区剩余量
System.out.println("当前交换区剩余量:" + df.format((float)swap.getFree() / 1024/1024/1024) + "G");
} catch (SigarException e) {
e.printStackTrace();
}
}
/**
* 3.操作系统信息
*
*/
// a)取到当前操作系统的名称:
public String getPlatformName() {
String hostname = "";
try {
hostname = InetAddress.getLocalHost().getHostName();
} catch (Exception exc) {
Sigar sigar = new Sigar();
try {
hostname = sigar.getNetInfo().getHostName();
} catch (SigarException e) {
hostname = "localhost.unknown";
} finally {
sigar.close();
}
}
return hostname;
}
// b)取当前操作系统的信息
public void testGetOSInfo() {
OperatingSystem OS = OperatingSystem.getInstance();
// 操作系统内核类型如: 386、486、586等x86
System.out.println("OS.getArch() = " + OS.getArch());
System.out.println("OS.getCpuEndian() = " + OS.getCpuEndian());//
System.out.println("OS.getDataModel() = " + OS.getDataModel());//
// 系统描述
System.out.println("OS.getDescription() = " + OS.getDescription());
System.out.println("OS.getMachine() = " + OS.getMachine());//
// 操作系统类型
System.out.println("OS.getName() = " + OS.getName());
System.out.println("OS.getPatchLevel() = " + OS.getPatchLevel());//
// 操作系统的卖主
System.out.println("OS.getVendor() = " + OS.getVendor());
// 卖主名称
System.out
.println("OS.getVendorCodeName() = " + OS.getVendorCodeName());
// 操作系统名称
System.out.println("OS.getVendorName() = " + OS.getVendorName());
// 操作系统卖主类型
System.out.println("OS.getVendorVersion() = " + OS.getVendorVersion());
// 操作系统的版本号
System.out.println("OS.getVersion() = " + OS.getVersion());
}
// c)取当前系统进程表中的用户信息
public void testWho() {
try {
Sigar sigar = new Sigar();
org.hyperic.sigar.Who[] who = sigar.getWhoList();
if (who != null && who.length > 0) {
for (int i = 0; i < who.length; i++) {
System.out.println("\n~~~~~~~~~" + String.valueOf(i)
+ "~~~~~~~~~");
org.hyperic.sigar.Who _who = who[i];
System.out.println("获取设备getDevice() = " + _who.getDevice());
System.out.println("获得主机getHost() = " + _who.getHost());
System.out.println("获取的时间getTime() = " + _who.getTime());
// 当前系统进程表中的用户名
System.out.println("获取用户getUser() = " + _who.getUser());
}
}
} catch (SigarException e) {
e.printStackTrace();
}
}
// 4.资源信息(主要是硬盘)
// a)取硬盘已有的分区及其详细信息(通过sigar.getFileSystemList()来获得FileSystem列表对象,然后对其进行编历):
public void testFileSystemInfo() throws Exception {
Sigar sigar = new Sigar();
FileSystem fslist[] = sigar.getFileSystemList();
DecimalFormat df = new DecimalFormat("#0.00");
// String dir = System.getProperty("user.home");// 当前用户文件夹路径
for (int i = 0; i < fslist.length; i++) {
System.out.println("\n~~~~~~~~~~" + i + "~~~~~~~~~~");
FileSystem fs = fslist[i];
// 分区的盘符名称
System.out.println("fs.getDevName() = " + fs.getDevName());
// 分区的盘符名称
System.out.println("fs.getDirName() = " + fs.getDirName());
System.out.println("fs.getFlags() = " + fs.getFlags());//
// 文件系统类型,比如 FAT32、NTFS
System.out.println("fs.getSysTypeName() = " + fs.getSysTypeName());
// 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
System.out.println("fs.getTypeName() = " + fs.getTypeName());
// 文件系统类型
System.out.println("fs.getType() = " + fs.getType());
FileSystemUsage usage = null;
try {
usage = sigar.getFileSystemUsage(fs.getDirName());
} catch (SigarException e) {
if (fs.getType() == 2)
throw e;
continue;
}
switch (fs.getType()) {
case 0: // TYPE_UNKNOWN :未知
break;
case 1: // TYPE_NONE
break;
case 2: // TYPE_LOCAL_DISK : 本地硬盘
// 文件系统总大小
System.out.println(" Total = " + df.format((float)usage.getTotal()/1024/1024) + "G");
// 文件系统剩余大小
System.out.println(" Free = " + df.format((float)usage.getFree()/1024/1024) + "G");
// 文件系统可用大小
System.out.println(" Avail = " + df.format((float)usage.getAvail()/1024/1024) + "G");
// 文件系统已经使用量
System.out.println(" Used = " + df.format((float)usage.getUsed()/1024/1024) + "G");
double usePercent = usage.getUsePercent() * 100D;
// 文件系统资源的利用率
System.out.println(" Usage = " + df.format(usePercent) + "%");
break;
case 3:// TYPE_NETWORK :网络
break;
case 4:// TYPE_RAM_DISK :闪存
break;
case 5:// TYPE_CDROM :光驱
break;
case 6:// TYPE_SWAP :页面交换
break;
}
System.out.println(" DiskReads = " + usage.getDiskReads());
System.out.println(" DiskWrites = " + usage.getDiskWrites());
}
return;
}
// 5.网络信息
// a)当前机器的正式域名
public String getFQDN() {
Sigar sigar = null;
try {
return InetAddress.getLocalHost().getCanonicalHostName();
} catch (UnknownHostException e) {
try {
sigar = new Sigar();
return sigar.getFQDN();
} catch (SigarException ex) {
return null;
} finally {
sigar.close();
}
}
}
// b)取到当前机器的IP地址
public String getDefaultIpAddress() {
String address = null;
try {
address = InetAddress.getLocalHost().getHostAddress();
// 没有出现异常而正常当取到的IP时,如果取到的不是网卡循回地址时就返回
// 否则再通过Sigar工具包中的方法来获取
if (!NetFlags.LOOPBACK_ADDRESS.equals(address)) {
return address;
}
} catch (UnknownHostException e) {
// hostname not in DNS or /etc/hosts
}
Sigar sigar = new Sigar();
try {
address = sigar.getNetInterfaceConfig().getAddress();
} catch (SigarException e) {
address = NetFlags.LOOPBACK_ADDRESS;
} finally {
sigar.close();
}
return address;
}
// c)取到当前机器的MAC地址
public String getMAC() {
Sigar sigar = null;
try {
sigar = new Sigar();
String[] ifaces = sigar.getNetInterfaceList();
String hwaddr = null;
for (int i = 0; i < ifaces.length; i++) {
NetInterfaceConfig cfg = sigar.getNetInterfaceConfig(ifaces[i]);
if (NetFlags.LOOPBACK_ADDRESS.equals(cfg.getAddress())
|| (cfg.getFlags() & NetFlags.IFF_LOOPBACK) != 0
|| NetFlags.NULL_HWADDR.equals(cfg.getHwaddr())) {
continue;
}
/*
* 如果存在多张网卡包括虚拟机的网卡,默认只取第一张网卡的MAC地址,如果要返回所有的网卡(包括物理的和虚拟的)则可以修改方法的返回类型为数组或Collection
* ,通过在for循环里取到的多个MAC地址。
*/
hwaddr = cfg.getHwaddr();
break;
}
return hwaddr != null ? hwaddr : null;
} catch (Exception e) {
return null;
} finally {
if (sigar != null)
sigar.close();
}
}
// d)获取网络流量等信息
public void testNetIfList() throws Exception {
Sigar sigar = new Sigar();
String ifNames[] = sigar.getNetInterfaceList();
for (int i = 0; i < ifNames.length; i++) {
String name = ifNames[i];
NetInterfaceConfig ifconfig = sigar.getNetInterfaceConfig(name);
print("\nname = " + name);// 网络设备名
print("Address = " + ifconfig.getAddress());// IP地址
print("Netmask = " + ifconfig.getNetmask());// 子网掩码
if ((ifconfig.getFlags() & 1L) <= 0L) {
print("!IFF_UP...skipping getNetInterfaceStat");
continue;
}
try {
NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
print("RxPackets = " + ifstat.getRxPackets());// 接收的总包裹数
print("TxPackets = " + ifstat.getTxPackets());// 发送的总包裹数
print("RxBytes = " + ifstat.getRxBytes());// 接收到的总字节数
print("TxBytes = " + ifstat.getTxBytes());// 发送的总字节数
print("RxErrors = " + ifstat.getRxErrors());// 接收到的错误包数
print("TxErrors = " + ifstat.getTxErrors());// 发送数据包时的错误数
print("RxDropped = " + ifstat.getRxDropped());// 接收时丢弃的包数
print("TxDropped = " + ifstat.getTxDropped());// 发送时丢弃的包数
} catch (SigarNotImplementedException e) {
} catch (SigarException e) {
print(e.getMessage());
}
}
}
void print(String msg) {
System.out.println(msg);
}
// e)一些其他的信息
public void getEthernetInfo() {
Sigar sigar = null;
try {
sigar = new Sigar();
String[] ifaces = sigar.getNetInterfaceList();
for (int i = 0; i < ifaces.length; i++) {
NetInterfaceConfig cfg = sigar.getNetInterfaceConfig(ifaces[i]);
if (NetFlags.LOOPBACK_ADDRESS.equals(cfg.getAddress())
|| (cfg.getFlags() & NetFlags.IFF_LOOPBACK) != 0
|| NetFlags.NULL_HWADDR.equals(cfg.getHwaddr())) {
continue;
}
System.out.println("cfg.getAddress() = " + cfg.getAddress());// IP地址
System.out
.println("cfg.getBroadcast() = " + cfg.getBroadcast());// 网关广播地址
System.out.println("cfg.getHwaddr() = " + cfg.getHwaddr());// 网卡MAC地址
System.out.println("cfg.getNetmask() = " + cfg.getNetmask());// 子网掩码
System.out.println("cfg.getDescription() = "
+ cfg.getDescription());// 网卡描述信息
System.out.println("cfg.getType() = " + cfg.getType());//
System.out.println("cfg.getDestination() = "
+ cfg.getDestination());
System.out.println("cfg.getFlags() = " + cfg.getFlags());//
System.out.println("cfg.getMetric() = " + cfg.getMetric());
System.out.println("cfg.getMtu() = " + cfg.getMtu());
System.out.println("cfg.getName() = " + cfg.getName());
System.out.println();
}
} catch (Exception e) {
System.out.println("Error while creating GUID" + e);
} finally {
if (sigar != null)
sigar.close();
}
}
}
Java如何实现系统监控、系统信息收集(转的更多相关文章
- ava如何实现系统监控、系统信息收集、sigar开源API的学习(转)
ava如何实现系统监控.系统信息收集.sigar开源API的学习(转) 转自:http://liningjustsoso.iteye.com/blog/1254584 首先给大家介绍一个开源工具Sig ...
- Java系统监控(淘汰sigar)
Sigar是Hyperic-hq产品的基础包,是Hyperic HQ主要的数据收集组件.它用来从许多平台收集系统和处理信息. 这些平台包括:Linux, Windows, Solaris, AIX, ...
- Linux系统监控命令及如何定位到Java线程
>>PID.TID的区分 uid是user id,即用户id,root用户的uid是0,0为最高权限,gid是group id,用户组id,使用 id 命令可以很简单的通过用户名查看UID ...
- [原创]Java应用性能远程监控系统(C/S架构)
Java应用性能远程监控系统(使用C/S架构) 适用于监控所有Java应用,具有堆内存监控.方法区监控.GC监控.类加载监控.类编译监控与线程监控,提供堆快照下载,线程快照下载.体验网址:http:/ ...
- Linux系统监控命令及定位Java线程
1.PID.TID的区分 uid是user id,即用户id,root用户的uid是0,0为最高权限,gid是group id,用户组id,使用 id 命令可以很简单的通过用户名查看UID.GID:~ ...
- StatsD!次世代系统监控的核心
在互联网业务蒸蒸日上的今时今日,系统架构日渐复杂,随着软件产品和工程团队的变革,许多开源的监控工具应运而生,其中有一些相当出名,比如 Zabbix.Nagios 还有 StatsD.也有一些问题被大家 ...
- linux系统监控常用工具
linux系统监控常用工具 一.系统核心工具包(coreutils) 1./bin/df 报告系统的磁盘空间用量 df -h 显示磁盘分区fdisk -l 2./bin/uname 显示系统信息 u ...
- 【linux之进程管理,系统监控】
一.进程管理 前台进程:一般是指占据着标准输入和/或标准输出的进程后台进程:不占据默认开启的进程都是前台进程ctrl+C 中断ctrl+z 从前台转入后台bg 后台进程编号 让其在后台运行ls -R ...
- JAVA开源B2C系统
前言 最近有人想面向境外销售商品,但是又不想依托于亚马逊这些平台,于是找我来帮忙想弄个B2C系统.因为刚开始只是打算试试水,也就不打算投入多少成本了.所以这边就考虑使用开源的B2C系统来直接使用了. ...
随机推荐
- [hdu 3068] Manacher算法O(n)最长回文子串
一个不错的讲解:https://github.com/julycoding/The-Art-Of-Programming-By-July/blob/master/ebook/zh/01.05.md # ...
- Codeforces Round #525 (Div. 2)A. Ehab and another construction problem
A. Ehab and another construction problem 题目链接:https://codeforc.es/contest/1088/problem/A 题意: 给出一个x,找 ...
- node搭建文件服务器
python可以在目录下python -m http.server 8080来启动一个静态文件服务器,使用node实现一个 运行node fileServer.js D:\lanFeature 即可将 ...
- oracle12c创建用户等问题
一:前言 这几天我重新装了下电脑,然后自己有试着去装了下oracle11g,结果还是失败了然后我自己又去下载了最新的oracle12c,oracle12c中有两个用户sys和system,scott已 ...
- win 7 64 位系统驱动签名
自己开发未经签名的驱动无法加载,关闭Windows 7系统中的驱动签名强制要求 bcdedit.exe -set loadoptions DDISABLE_INTEGRITY_CHECKS
- COGS2642 / Bzoj4590 [Shoi2015]自动刷题机
Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 906 Solved: 321 Description 曾经发明了信号增幅仪的发明家SHTSC又公开了 ...
- BZOJ1082_栅栏_C++
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1082 题解:http://www.cnblogs.com/hadilo/p/5924546.h ...
- bzoj 1083 最小生成树
裸的最小生成树. /************************************************************** Problem: User: BLADEVIL Lan ...
- 解决小米/红米手机无法进行jdwp调试的问题
问题描述:在逆向一个app,研究环境是一台红米2,需要使用jdwp接口,也就是ddms下面这个界面: 但神奇的是,同一台主机上,模拟器的进程可以显示在ddms界面上,红米2确一个进程都没有显示出来.c ...
- Linux内核同步机制之(四):spin lock【转】
转自:http://www.wowotech.net/kernel_synchronization/spinlock.html 一.前言 在linux kernel的实现中,经常会遇到这样的场景:共享 ...