Sigar是Hyperic-hq产品的基础包,是Hyperic HQ主要的数据收集组件。它用来从许多平台收集系统和处理信息.

这些平台包括:Linux, Windows, Solaris, AIX, HP-UX, FreeBSD and Mac OSX.

Sigar有C,C#,Java和Perl API,java版的API为sigar.jar sigar.jar的底层是用C语言编写的,它通过本地方法来调用操作系统API来获取系统相关数据。Windows操作系统下Sigar.jar 依赖sigar-amd64-winnt.dll或sigar-x86-winnt.dll,linux 操作系统下则依赖libsigar-amd64-linux.so或libsigar-x86-linux.so

Hyperic-hq官方网站:http://www.hyperic.com

Sigar.jar下载地址:http://sigar.hyperic.com

Sigar API 提供一个方便的接口来收集系统信息,如:

◆系统内存,页面交换,cpu,平均负载,运行时间,登录信息

◆每个进程占用的内存,cpu,帐号信息,状态,参数,环境,打开的文件

◆文件系统探测和度量

◆网络接口探测,配置信息和度量

◆网络路由和连接表

获取cpu信息代码 
// CPU数量(单位:个)
int cpuLength = sigar.getCpuInfoList().length;
print(cpuLength);// CPU的总量(单位:HZ)及CPU的相关信息
CpuInfo infos[] = sigar.getCpuInfoList();
for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用CpuInfo info = infos[i];print("mhz=" + info.getMhz());// CPU的总量MHzprint("vendor=" + info.getVendor());// 获得CPU的卖主,如:Intelprint("model=" + info.getModel());// 获得CPU的类别,如:Celeronprint("cache size=" + info.getCacheSize());// 缓冲存储器数量
}/** CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%) **/
// 方式一,主要是针对一块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();
}
for (int i = 0; i < cpuList.length; i++) {// printCpuPerc(cpuList[i]);
}
// CPU数量(单位:个)
int cpuLength = sigar.getCpuInfoList().length;
print(cpuLength);// CPU的总量(单位:HZ)及CPU的相关信息
CpuInfo infos[] = sigar.getCpuInfoList();
for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用CpuInfo info = infos[i];print("mhz=" + info.getMhz());// CPU的总量MHzprint("vendor=" + info.getVendor());// 获得CPU的卖主,如:Intelprint("model=" + info.getModel());// 获得CPU的类别,如:Celeronprint("cache size=" + info.getCacheSize());// 缓冲存储器数量
}/** CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%) **/
// 方式一,主要是针对一块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();
}
for (int i = 0; i < cpuList.length; i++) {// printCpuPerc(cpuList[i]);
}
获取内存信息代码  
// 物理内存信息
Mem mem = sigar.getMem();
// 内存总量
print("Total = " + mem.getTotal() / 1024L / 1024 + "M av");
// 当前内存使用量
print("Used = " + mem.getUsed() / 1024L / 1024 + "M used");
// 当前内存剩余量
print("Free = " + mem.getFree() / 1024L / 1024 + "M free");// 系统页面文件交换区信息
Swap swap = sigar.getSwap();
// 交换区总量
print("Total = " + swap.getTotal() / 1024L + "K av");
// 当前交换区使用量
print("Used = " + swap.getUsed() / 1024L + "K used");
// 当前交换区剩余量
print("Free = " + swap.getFree() / 1024L + "K free");
// 物理内存信息
Mem mem = sigar.getMem();
// 内存总量
print("Total = " + mem.getTotal() / 1024L / 1024 + "M av");
// 当前内存使用量
print("Used = " + mem.getUsed() / 1024L / 1024 + "M used");
// 当前内存剩余量
print("Free = " + mem.getFree() / 1024L / 1024 + "M free");// 系统页面文件交换区信息
Swap swap = sigar.getSwap();
// 交换区总量
print("Total = " + swap.getTotal() / 1024L + "K av");
// 当前交换区使用量
print("Used = " + swap.getUsed() / 1024L + "K used");
// 当前交换区剩余量
print("Free = " + swap.getFree() / 1024L + "K free");
获取操作系统信息代码  
 // 取到当前操作系统的名称
String hostname = "";
try {hostname = InetAddress.getLocalHost().getHostName();
} catch (Exception exc) {try {hostname = sigar.getNetInfo().getHostName();} catch (SigarException e) {hostname = "localhost.unknown";} finally {sigar.close();}
}
print(hostname);// 取当前操作系统的信息
OperatingSystem OS = OperatingSystem.getInstance();
// 操作系统内核类型如: 386、486、586等x86
print("OS.getArch() = " + OS.getArch());
print("OS.getCpuEndian() = " + OS.getCpuEndian());//
print("OS.getDataModel() = " + OS.getDataModel());//
// 系统描述
print("OS.getDescription() = " + OS.getDescription());
print("OS.getMachine() = " + OS.getMachine());//
// 操作系统类型
print("OS.getName() = " + OS.getName());
print("OS.getPatchLevel() = " + OS.getPatchLevel());//
// 操作系统的卖主
print("OS.getVendor() = " + OS.getVendor());
// 卖主名称
System.out.println("OS.getVendorCodeName() = " + OS.getVendorCodeName());
// 操作系统名称
print("OS.getVendorName() = " + OS.getVendorName());
// 操作系统卖主类型
print("OS.getVendorVersion() = " + OS.getVendorVersion());
// 操作系统的版本号
print("OS.getVersion() = " + OS.getVersion());// 取当前系统进程表中的用户信息
Who who[] = sigar.getWhoList();
if (who != null && who.length > 0) {for (int i = 0; i < who.length; i++) {print("\n~~~~~~~~~" + String.valueOf(i) + "~~~~~~~~~");Who _who = who[i];print("getDevice() = " + _who.getDevice());print("getHost() = " + _who.getHost());print("getTime() = " + _who.getTime());// 当前系统进程表中的用户名print("getUser() = " + _who.getUser());}
}
// 取到当前操作系统的名称
String hostname = "";
try {hostname = InetAddress.getLocalHost().getHostName();
} catch (Exception exc) {try {hostname = sigar.getNetInfo().getHostName();} catch (SigarException e) {hostname = "localhost.unknown";} finally {sigar.close();}
}
print(hostname);// 取当前操作系统的信息
OperatingSystem OS = OperatingSystem.getInstance();
// 操作系统内核类型如: 386、486、586等x86
print("OS.getArch() = " + OS.getArch());
print("OS.getCpuEndian() = " + OS.getCpuEndian());//
print("OS.getDataModel() = " + OS.getDataModel());//
// 系统描述
print("OS.getDescription() = " + OS.getDescription());
print("OS.getMachine() = " + OS.getMachine());//
// 操作系统类型
print("OS.getName() = " + OS.getName());
print("OS.getPatchLevel() = " + OS.getPatchLevel());//
// 操作系统的卖主
print("OS.getVendor() = " + OS.getVendor());
// 卖主名称
System.out.println("OS.getVendorCodeName() = " + OS.getVendorCodeName());
// 操作系统名称
print("OS.getVendorName() = " + OS.getVendorName());
// 操作系统卖主类型
print("OS.getVendorVersion() = " + OS.getVendorVersion());
// 操作系统的版本号
print("OS.getVersion() = " + OS.getVersion());// 取当前系统进程表中的用户信息
Who who[] = sigar.getWhoList();
if (who != null && who.length > 0) {for (int i = 0; i < who.length; i++) {print("\n~~~~~~~~~" + String.valueOf(i) + "~~~~~~~~~");Who _who = who[i];print("getDevice() = " + _who.getDevice());print("getHost() = " + _who.getHost());print("getTime() = " + _who.getTime());// 当前系统进程表中的用户名print("getUser() = " + _who.getUser());}
}
获取磁盘信息代码  
//列表对象,然后对其进行编历
FileSystem fslist[] = sigar.getFileSystemList();
String dir = System.getProperty("user.home");// 当前用户文件夹路径
print(dir + "   " + fslist.length);
for (int i = 0; i < fslist.length; i++) {print("\n~~~~~~~~~~" + i + "~~~~~~~~~~");
FileSystem fs = fslist[i];
// 分区的盘符名称
print("fs.getDevName() = " + fs.getDevName());
// 分区的盘符名称
print("fs.getDirName() = " + fs.getDirName());
print("fs.getFlags() = " + fs.getFlags());//
// 文件系统类型,比如 FAT32、NTFS
print("fs.getSysTypeName() = " + fs.getSysTypeName());
// 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
print("fs.getTypeName() = " + fs.getTypeName());
// 文件系统类型
print("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_NONEbreak;
case 2: // TYPE_LOCAL_DISK : 本地硬盘// 文件系统总大小print(" Total = " + usage.getTotal() + "KB");// 文件系统剩余大小print(" Free = " + usage.getFree() + "KB");// 文件系统可用大小print(" Avail = " + usage.getAvail() + "KB");// 文件系统已经使用量print(" Used = " + usage.getUsed() + "KB");double usePercent = usage.getUsePercent() * 100D;// 文件系统资源的利用率print(" Usage = " + usePercent + "%");break;
case 3:// TYPE_NETWORK :网络break;
case 4:// TYPE_RAM_DISK :闪存break;
case 5:// TYPE_CDROM :光驱break;
case 6:// TYPE_SWAP :页面交换break;
}
print(" DiskReads = " + usage.getDiskReads());
print(" DiskWrites = " + usage.getDiskWrites());
}
// 取硬盘已有的分区及其详细信息(通过sigar.getFileSystemList()来获得FileSystem列表对象,然后对其进行编历
FileSystem fslist[] = sigar.getFileSystemList();
String dir = System.getProperty("user.home");// 当前用户文件夹路径
print(dir + "   " + fslist.length);
for (int i = 0; i < fslist.length; i++) {print("\n~~~~~~~~~~" + i + "~~~~~~~~~~");
FileSystem fs = fslist[i];
// 分区的盘符名称
print("fs.getDevName() = " + fs.getDevName());
// 分区的盘符名称
print("fs.getDirName() = " + fs.getDirName());
print("fs.getFlags() = " + fs.getFlags());//
// 文件系统类型,比如 FAT32、NTFS
print("fs.getSysTypeName() = " + fs.getSysTypeName());
// 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
print("fs.getTypeName() = " + fs.getTypeName());
// 文件系统类型
print("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_NONEbreak;
case 2: // TYPE_LOCAL_DISK : 本地硬盘// 文件系统总大小print(" Total = " + usage.getTotal() + "KB");// 文件系统剩余大小print(" Free = " + usage.getFree() + "KB");// 文件系统可用大小print(" Avail = " + usage.getAvail() + "KB");// 文件系统已经使用量print(" Used = " + usage.getUsed() + "KB");double usePercent = usage.getUsePercent() * 100D;// 文件系统资源的利用率print(" Usage = " + usePercent + "%");break;
case 3:// TYPE_NETWORK :网络break;
case 4:// TYPE_RAM_DISK :闪存break;
case 5:// TYPE_CDROM :光驱break;
case 6:// TYPE_SWAP :页面交换break;
}
print(" DiskReads = " + usage.getDiskReads());
print(" DiskWrites = " + usage.getDiskWrites());
}
获取网络信息代码  
// 当前机器的正式域名
try {print(InetAddress.getLocalHost().getCanonicalHostName());
} catch (UnknownHostException e) {try {print(sigar.getFQDN());} catch (SigarException ex) {} finally {sigar.close();}
}// 取到当前机器的IP地址
String address = null;
try {address = InetAddress.getLocalHost().getHostAddress();// 没有出现异常而正常当取到的IP时,如果取到的不是网卡循回地址时就返回// 否则再通过Sigar工具包中的方法来获取print(address);if (!NetFlags.LOOPBACK_ADDRESS.equals(address)) {}
} catch (UnknownHostException e) {// hostname not in DNS or /etc/hosts
}
try {address = sigar.getNetInterfaceConfig().getAddress();
} catch (SigarException e) {address = NetFlags.LOOPBACK_ADDRESS;
} finally {
}
print(address);// 取到当前机器的MAC地址
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;}hwaddr = cfg.getHwaddr();print(hwaddr);// break;
}
print(hwaddr != null ? hwaddr : null);// 获取网络流量等信息
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());}
}// 一些其他的信息
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;}print("cfg.getAddress() = " + cfg.getAddress());// IP地址print("cfg.getBroadcast() = " + cfg.getBroadcast());// 网关广播地址print("cfg.getHwaddr() = " + cfg.getHwaddr());// 网卡MAC地址print("cfg.getNetmask() = " + cfg.getNetmask());// 子网掩码System.out.println("cfg.getDescription() = " + cfg.getDescription());// 网卡描述信息print("cfg.getType() = " + cfg.getType());//System.out.println("cfg.getDestination() = " + cfg.getDestination());print("cfg.getFlags() = " + cfg.getFlags());//print("cfg.getMetric() = " + cfg.getMetric());print("cfg.getMtu() = " + cfg.getMtu());print("cfg.getName() = " + cfg.getName());
}

sigar 获取跨平台服务器信息相关推荐

  1. 无法获取到服务器信息,未获取到服务器信息

    未获取到服务器信息 内容精选 换一换 无法正常使用Cloud-init.弹性云服务器获取Metadata的流程如图1所示:获取Metadata流程图您可以按照以下原因进行排查,如果解决完某个可能原因仍 ...

  2. ios获取区域服务器信息,ios获取服务器数据

    ios获取服务器数据 内容精选 换一换 调用API出错后,将不会返回结果数据.调用方可根据每个API对应的错误码来定位错误原因.当调用出错时,HTTP请求返回一个4xx或5xx的HTTP状态码.返回的 ...

  3. 怎么获取别人服务器信息失败,获取服务器信息失败

    获取服务器信息失败 内容精选 换一换 1.若希望以主席身份入会,enter_code必须传入主席密码.若希望以来宾身份入会,当会议要求来宾密码时,enter_code必须传入来宾密码,会议不要求来宾密 ...

  4. java 获取远程服务器信息,java 远程获取服务器信息

    java 远程获取服务器信息 内容精选 换一换 已成功登录Java性能分析.待安装Guardian的服务器已开启sshd.待安装Guardian的服务器已安装JRE,JRE版本要求为Huawei JD ...

  5. .Net Core 获取Linux服务器信息

    创建ServerConfig类 public class ServerConfig{//static private log4net.ILog log = log4net.LogManager.Get ...

  6. js获取当前服务器信息,js 获取当前服务器的地址

    js 获取当前服务器的地址 内容精选 换一换 DHCP无法正常获取内网IP,当DHCP无法正常获取内网IP时,不同系统的云服务器表现如下:Linux系统表现为无法获取内网IP.windows系统由于自 ...

  7. 获取protal服务器信息超时,portal服务器

    portal服务器 内容精选 换一换 配置云AP的SSID时支持的认证方式多达13种,但是常用且推荐使用的认证方式有:密码认证(PSK):设置无线终端接入无线网络时需要输入的密码.Portal认证:i ...

  8. Redis获取客户端 服务器信息常用命令

    AUTH password 通过设置配置文件中 requirepass 项的值(使用命令 CONFIG SET requirepass password ),可以使用密码来保护 Redis 服务器. ...

  9. 获取Minecraft服务器信息API,Minecraft快速实现Yggdrasil API正版验证

    2020年2月15日 阴 又是无聊的一天,病毒肆虐,哪也去不了,一年更新一次文章 Minecraft一般国内都是使用离线验证及盗版账号 如果想使用正版验证的话需要购买账号账号,但是也可以自己造一个正版 ...

  10. 获取portal服务器信息超时,由于大量Portal用户同时认证导致Portal服务器处理报文超时造成一个Portal用户也认证不上的问题...

    由于大量Portal用户同时认证导致Portal服务器处理报文超时造成一个Portal用户也认证不上问题的解决方法 一.组网: 使用iMC UAM做Portal认证,客户端采用网页或iNode方式. ...

最新文章

  1. 汇编: mul乘法指令
  2. Linux练习(write写入)
  3. java nio connect_Java NIO系列教程(八) SocketChannel
  4. Python Email发送,通知业务完成
  5. leetcode 220. 存在重复元素 III(排序)
  6. SQL Server provider: SQL 网络接口, error: 26 - 定位指定的服务器/实例时出错
  7. win7备份工具_一键重装win7系统教程,如何重装win7系统
  8. 保留五天的日志 php,怎样让日志在归档目录保留5天?
  9. linux有名管道 复用,Linux进程间通信(九)---综合实验之有名管道通信实验
  10. mysql的架构及查询sql的执行流程(二)
  11. linux编译安装openssl-3.0.2
  12. 元器件及测量基础实验
  13. 掌阅电子书全系列安装第三方app教程(无需破解)
  14. 九宫格数独游戏——回溯算法——java实现
  15. IRC下载TLF0day资源
  16. OpenCV C++案例实战三《二维码检测》
  17. iOS开发中的Web应用概述
  18. 在重启Linux系统中把内存,在重新启动Linux系统的同时把内存中的信息写入硬盘,应使用()...
  19. 大数据剖析| 二线城市抢人大战,拼的到底是什么?
  20. UG背景颜色修改和截图

热门文章

  1. Macbook pro新手入门
  2. 将python项目部署到Docker
  3. 微信开发者工具下载地址
  4. python 帮助文档下载地址
  5. 区块链技术指南之分布式的一致性
  6. 软件测试订单测试用例,测试用例 - 进销存软件测试.doc
  7. springboot集成quartz,简版-通俗易懂
  8. python不同版本切换_Python版本切换,python,的
  9. 浏览器网页视频下载Video Octopus插件网页视频下载插件
  10. Jmeter 及 JDK 下载 安装教程