Hyperic-Sigar简介——检测与监控
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简介——检测与监控的更多相关文章
- Hyperic Sigar API 举例
Hyperic HQ 是什么? Hyperic HQ 是一个开源的(General Public License,GPL授权)IT资源管理框架,让用户使用统一的界面来管理各种不同的IT资源的管理,Hy ...
- java sigar获取本地信息以及org.hyperic.sigar.SigarException: The device is not ready报错解决
window下,使用java sigar 获取磁盘使用率,cpu使用率以及内存使用情况等信息时. 一:首先需要下载jar包和相关文件 sigar-1.6.4.zip 如果想了解更多可以去 sigar官 ...
- Java虚拟机性能管理神器 - VisualVM(1) 简介 - JVM轻量级监控分析神器
目录(?)[-] 一VisualVM是什么 二如何获取VisualVM 三获取那个版本 四VisualVM能做什么 显示JAVA应用程序配置和运行时环境 显示本地和远程JAVA应用程序运行状态 监控应 ...
- 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 ...
- Facebook开源的基于SQL的操作系统检测和监控框架:osquery
osquery简介 osquery是一款由facebook开源的,面向OSX和Linux的操作系统检测框架. osquery顾名思义,就是query os,允许通过使用SQL的方式来获取操作系统的数据 ...
- Sigar简介
大家好,我是Sigar.也许好多人还不认识我.下面就介绍一下我自己,好让大家对我有一个大致的了解. 我的全名是System Information Gatherer And Reporter,中文名是 ...
- Facebook开源的基于SQL的操作系统检测和监控框架:osquery daemon详解
osqueryd osqueryd(osquery daemon)是可以定期执行SQL查询和记录系统状态改变的驻守程序. osqueryd能够根据配置手机归档查询结果,并产生日志. 同时也可以使用系统 ...
- Facebook开源的基于SQL的操作系统检测和监控框架:osquery Table详解
写在前面 上一篇介绍了osquery的一些用法,即如何使用SQL语句查询系统信息.本文就来介绍下这个table是如何定义的,及table中的数据是如何取得的. 本文以uptime和process两张表 ...
- ava如何实现系统监控、系统信息收集、sigar开源API的学习(转)
ava如何实现系统监控.系统信息收集.sigar开源API的学习(转) 转自:http://liningjustsoso.iteye.com/blog/1254584 首先给大家介绍一个开源工具Sig ...
随机推荐
- 协同过滤算法 teamCF
http://www.infoq.com/cn/articles/recommendation-algorithm-overview-part02
- Servlet -- 中文乱码解决
请求:对于get和post都有效果 request.setCharacterEncoding("UTF-8"); 相应: 设置服务器输出的编码为UTF-8 response.set ...
- js jquery radio 选中 选中值
radio示例: <label><input type="radio" name="type" id="type" val ...
- java 数组声明定义 数组内存分配 数组初始化 数组引用 数组的遍历
一,数组的定义 Java 中定义数组的语法有两种: 1. type arrayName[]; 2. type[] arrayName;type 为Java中的任意数据类型,包括基本类型和组合类型,ar ...
- 跟着 underscore 学节流
更多内容请参考:我的新博客 在上一篇文章中,我们了解了为什么要限制事件的频繁触发,以及如何做限制: debounce 防抖 throttle 节流 上次已经说过防抖的实现了,今天主要来说一下节流的实现 ...
- cookie 常用操作
Cookie:指网站为了辨别用户身份.进行会话跟踪而储存在用户本地的 key/value 型数据(通常经过加密), cookie key/value 型数据可以由服务器端自己定义. Cookie是由服 ...
- react-native---rn中的修饰组件(TouchableHightlight、TouchableOpacity、TouchableNativeFeedback等)
react-native中View组件这是单纯的视图容器,并不能响应交互变化,绑定事件,rn提供了TouchableOpacity等封装组件以正确响应触摸操作. TouchableWithoutFee ...
- session会话对象
一.session会话对象介绍: 会话对象让你能够跨请求保持某些参数,它也会在同一个session实例发出的所有请求之间保持cookie. 二.步骤 1.对session对象进行一次实例化 2.进行登 ...
- log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息
log4j 配置,tomcat 启动或有后台操作时,控制台会显示很多 DEBUG 信息 日志信息可以以文件形式显示,也可以在控制台输出,在 log4j.properties 文件设置. 控制台有很多 ...
- idea 红线 并提示idea cant resolve symbol
能编译通过说明SDK导入正确,但是为啥我们点击每一个Java文件会出现好多红色的下划线 ,并提示idea cant resolve symbol原因就是可能没有清除原来的历史缓存,导致一些错误,解决方 ...