http://blog.csdn.net/liyong199012/article/details/20302761

Hyperic-Sigar是一个收集系统各项底层信息的工具集.他有如下特点:
1. 收集信息全面
收集CPU,MEM,NETWORK,PROCESS,IOSTAT等
使用Sigar,你完全可以模仿出cpuinfo,meminfo,top,free,ifconfig,ipconfig,netstat,route,df,du,ps,ls等多种unix平台和windows平台的指令.
2.跨平台,支持多数平台
支持的平台包括:windows系列(32系列,IA64系列,AMD64系列),Linux系列,freeBsd系列,HPUnix系列,Sun solaris/Sparc/Sparc64系列,macOs系列,AIX系列等
3.提供的API接口全面
sigar本身由C语言开发而成,提供了丰富的API接口,包括:Java,.NET,PERL,PHP,Python,RUBY.Sigar.jar包是通过本地方法来调用操作系统API来获取系统相关数据。Windows操作系统下Sigar.jar依赖sigar-amd64-winnt.dll或sigar-x86-winnt.dll,linux操作系统下则依赖libsigar-amd64-linux.so或libsigar-x86-linux.so……而Sigar.jar还依赖于jug-asl-2.0.0.jar、log4j-1.2.14.jar、Junit.jar,
Hyperic-hq官方网站:http://www.hyperic.com
Sigar.jar下载地址:http://sigar.hyperic.com
Sigar.jar包的使用方法: 1、 CPU资源信息
a) CPU数量(单位:个)
privatestaticint getCpuCount()throws SigarException {
Sigar sigar = new Sigar();
try {
returnsigar.getCpuInfoList().length;
} finally {
sigar.close();
}
}
b) CPU的总量(单位:HZ)及CPU的相关信息
Sigar sigar = getSigar();
CpuInfo infos[] = sigar.getCpuInfoList();
for (int i = 0; i< infos.length; i++){//不管是单块CPU还是多CPU都适用
CpuInfo info = infos[i];
traceln("mhz=" +info.getMhz());//CPU的总量MHz
traceln("vendor=" +info.getVendor());//获得CPU的卖主,如:Intel
traceln("model=" +info.getModel());//获得CPU的类别,如:Celeron
traceln("cache size=" +info.getCacheSize());//缓冲存储器数量
}
c) CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%)
publicvoid testCpuPerc() {
Sigar sigar= new Sigar();
// 方式一,主要是针对一块CPU的情况
CpuPerccpu;
try {
cpu =sigar.getCpuPerc();
printCpuPerc(cpu);
}catch (SigarException e) {
e.printStackTrace();
}
//方式二,不管是单块CPU还是多CPU都适用
CpuPerccpuList[] = null;
try {
cpuList =sigar.getCpuPercList();
}catch (SigarException e) {
e.printStackTrace();
return;
}
for (int i = 0; i< cpuList.length; i++) {
printCpuPerc(cpuList[i]);
}
}
privatevoid printCpuPerc(CpuPerc cpu) {
println("User :" +CpuPerc.format(cpu.getUser()));//用户使用率
println("Sys :" +CpuPerc.format(cpu.getSys()));// 系统使用率
println("Wait :" +CpuPerc.format(cpu.getWait()));//当前等待率
println("Nice :" +CpuPerc.format(cpu.getNice()));//
println("Idle :" +CpuPerc.format(cpu.getIdle()));//当前空闲率
println("Total :" +CpuPerc.format(cpu.getCombined()));//总的使用率
}
d) ……
2、 内存资源信息
a) 物理内存信息
Sigar sigar = new Sigar();
Mem mem = sigar.getMem();
// 内存总量
System.out.println("Total = " +mem.getTotal() / 1024L + "K av");
// 当前内存使用量
System.out.println("Used = " +mem.getUsed() / 1024L + "K used");
// 当前内存剩余量
System.out.println("Free = "+ mem.getFree() / 1024L + "K free");
b) 系统页面文件交换区信息
Sigar sigar = new Sigar();
Swap swap = sigar.getSwap();
// 交换区总量
System.out.println("Total = " +swap.getTotal() / 1024L + "K av");
// 当前交换区使用量
System.out.println("Used = " +swap.getUsed() / 1024L + "K used");
// 当前交换区剩余量
System.out.println("Free = "+ swap.getFree() / 1024L + "K free");
c) ……
3、 操作系统信息
a) 取到当前操作系统的名称:
private StringgetPlatformName() {
Stringhostname = "";
try {
hostname =InetAddress.getLocalHost().getHostName();
}catch (Exception exc) {
Sigarsigar = new Sigar();
try {
hostname= sigar.getNetInfo().getHostName();
}catch (SigarException e) {
hostname= "localhost.unknown";
}finally {
sigar.close();
}
}
return hostname;
}
b) 取当前操作系统的信息
publicvoid testGetOSInfo() {
OperatingSystemOS =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) 取当前系统进程表中的用户信息
publicvoid testWho() {
try {
Sigar sigar= new Sigar();
Who who[] =sigar.getWhoList();
if (who != null&& who.length> 0) {
for (int i = 0; i< who.length; i++) {
Sysout.out.println("\n~~~~~~~~~" +String.valueOf(i) + "~~~~~~~~~");
Who _who =who[i];
Sysout.out.println ("getDevice() = " +_who.getDevice());
Sysout.out.println ("getHost() = " +_who.getHost());
Sysout.out.println ("getTime() = " +_who.getTime());
//当前系统进程表中的用户名
Sysout.out.println ("getUser() = " +_who.getUser());
}
}
}catch (SigarException e) {
e.printStackTrace();
}
}
d) ……
4、 资源信息(主要是硬盘)
a) 取硬盘已有的分区及其详细信息(通过sigar.getFileSystemList()来获得FileSystem列表对象,然后对其进行编历):
publicvoid testFileSystemInfo()throws Exception {
Sigar sigar= getSigar();
FileSystemfslist[] = sigar.getFileSystemList();
String dir =System.getProperty("user.home");//当前用户文件夹路径
for (int i = 0; i< fslist.length; i++) {
System.out.println("\n~~~~~~~~~~"+ i + "~~~~~~~~~~");
FileSystemfs = 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= " + usage.getTotal() + "KB");
// 文件系统剩余大小
System.out.println(" Free= " + usage.getFree() + "KB");
// 文件系统可用大小
System.out.println(" Avail= " + usage.getAvail() + "KB");
// 文件系统已经使用量
System.out.println(" Used= " + usage.getUsed() + "KB");
double usePercent = usage.getUsePercent() *100D;
// 文件系统资源的利用率
System.out.println(" Usage= " + 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;
}
b) ……
5、 网络信息
a) 当前机器的正式域名
public StringgetFQDN(){
try {
returnInetAddress.getLocalHost().getCanonicalHostName();
}catch (UnknownHostException e) {
try {
Sigar sigar= new Sigar();
return sigar.getFQDN();
}catch (SigarException ex) {
returnnull;
}finally {
sigar.close();
}
}
}
b) 取到当前机器的IP地址
public StringgetDefaultIpAddress() {
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();
Stringhwaddr = 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;
} hwaddr = cfg.getHwaddr();
break;
}
return hwaddr != null ?hwaddr : null;
}catch (Exception e) {
returnnull;
}finally {
if (sigar !=null)
sigar.close();
}
}
d) 根据MAC地址来获得一个GUID号
public String getGUID(String mac) {
if (mac ==null)
returnnull;
EthernetAddress eAddr = newEthernetAddress(mac);
returnUUIDGenerator.getInstance().generateTimeBasedUUID(eAddr)
.toString();
}
e) 获取网络流量等信息
publicvoid testNetIfList()throws Exception {
Sigar sigar= new Sigar();
StringifNames[] = 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...skippinggetNetInterfaceStat");
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);
}
f) 一些其他的信息
privatevoid 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 whilecreating GUID" + e);
}finally {
if (sigar !=null)
sigar.close();
}
}

  

Hyperic-Sigar简介——检测与监控的更多相关文章

  1. Hyperic Sigar API 举例

    Hyperic HQ 是什么? Hyperic HQ 是一个开源的(General Public License,GPL授权)IT资源管理框架,让用户使用统一的界面来管理各种不同的IT资源的管理,Hy ...

  2. java sigar获取本地信息以及org.hyperic.sigar.SigarException: The device is not ready报错解决

    window下,使用java sigar 获取磁盘使用率,cpu使用率以及内存使用情况等信息时. 一:首先需要下载jar包和相关文件 sigar-1.6.4.zip 如果想了解更多可以去 sigar官 ...

  3. Java虚拟机性能管理神器 - VisualVM(1) 简介 - JVM轻量级监控分析神器

    目录(?)[-] 一VisualVM是什么 二如何获取VisualVM 三获取那个版本 四VisualVM能做什么 显示JAVA应用程序配置和运行时环境 显示本地和远程JAVA应用程序运行状态 监控应 ...

  4. 1 [main] DEBUG Sigar - no sigar-amd64-winnt.dll in java.library.path org.hyperic.sigar.SigarException: no sigar-amd64-winnt.dll in java.library.path

    github上一个java项目,在myeclipse中运行正常,生成jar后,运行报错: 1 [main] DEBUG Sigar - no sigar-amd64-winnt.dll in java ...

  5. Facebook开源的基于SQL的操作系统检测和监控框架:osquery

    osquery简介 osquery是一款由facebook开源的,面向OSX和Linux的操作系统检测框架. osquery顾名思义,就是query os,允许通过使用SQL的方式来获取操作系统的数据 ...

  6. Sigar简介

    大家好,我是Sigar.也许好多人还不认识我.下面就介绍一下我自己,好让大家对我有一个大致的了解. 我的全名是System Information Gatherer And Reporter,中文名是 ...

  7. Facebook开源的基于SQL的操作系统检测和监控框架:osquery daemon详解

    osqueryd osqueryd(osquery daemon)是可以定期执行SQL查询和记录系统状态改变的驻守程序. osqueryd能够根据配置手机归档查询结果,并产生日志. 同时也可以使用系统 ...

  8. Facebook开源的基于SQL的操作系统检测和监控框架:osquery Table详解

    写在前面 上一篇介绍了osquery的一些用法,即如何使用SQL语句查询系统信息.本文就来介绍下这个table是如何定义的,及table中的数据是如何取得的. 本文以uptime和process两张表 ...

  9. ava如何实现系统监控、系统信息收集、sigar开源API的学习(转)

    ava如何实现系统监控.系统信息收集.sigar开源API的学习(转) 转自:http://liningjustsoso.iteye.com/blog/1254584 首先给大家介绍一个开源工具Sig ...

随机推荐

  1. 协同过滤算法 teamCF

    http://www.infoq.com/cn/articles/recommendation-algorithm-overview-part02

  2. Servlet -- 中文乱码解决

    请求:对于get和post都有效果 request.setCharacterEncoding("UTF-8"); 相应: 设置服务器输出的编码为UTF-8 response.set ...

  3. js jquery radio 选中 选中值

    radio示例: <label><input type="radio" name="type" id="type" val ...

  4. java 数组声明定义 数组内存分配 数组初始化 数组引用 数组的遍历

    一,数组的定义 Java 中定义数组的语法有两种: 1. type arrayName[]; 2. type[] arrayName;type 为Java中的任意数据类型,包括基本类型和组合类型,ar ...

  5. 跟着 underscore 学节流

    更多内容请参考:我的新博客 在上一篇文章中,我们了解了为什么要限制事件的频繁触发,以及如何做限制: debounce 防抖 throttle 节流 上次已经说过防抖的实现了,今天主要来说一下节流的实现 ...

  6. cookie 常用操作

    Cookie:指网站为了辨别用户身份.进行会话跟踪而储存在用户本地的 key/value 型数据(通常经过加密), cookie key/value 型数据可以由服务器端自己定义. Cookie是由服 ...

  7. react-native---rn中的修饰组件(TouchableHightlight、TouchableOpacity、TouchableNativeFeedback等)

    react-native中View组件这是单纯的视图容器,并不能响应交互变化,绑定事件,rn提供了TouchableOpacity等封装组件以正确响应触摸操作. TouchableWithoutFee ...

  8. session会话对象

    一.session会话对象介绍: 会话对象让你能够跨请求保持某些参数,它也会在同一个session实例发出的所有请求之间保持cookie. 二.步骤 1.对session对象进行一次实例化 2.进行登 ...

  9. log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息

    log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息 日志信息可以以文件形式显示,也可以在控制台输出,在 log4j.properties 文件设置. 控制台有很多 ...

  10. idea 红线 并提示idea cant resolve symbol

    能编译通过说明SDK导入正确,但是为啥我们点击每一个Java文件会出现好多红色的下划线 ,并提示idea cant resolve symbol原因就是可能没有清除原来的历史缓存,导致一些错误,解决方 ...