sigar 获取跨平台服务器信息

sigar 获取跨平台服务器信息Sigar 是 Hyperic hq 产品的基础包 是 HypericHQ 主要的数据收集组件 它用来从许多平台收集系统和处理信息 这些平台包括 Linux Windows Solaris AIX HP UX FreeBSDandMa Sigar 有 C C Java 和 PerlAPI java 版的 API 为 sigar jarsigar jar 的底层是用 C 语言编写的 它通过本

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的总量MHz print("vendor=" + info.getVendor());// 获得CPU的卖主,如:Intel print("model=" + info.getModel());// 获得CPU的类别,如:Celeron print("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]); } 

获取内存信息代码  
sigar 获取跨平台服务器信息

// 物理内存信息 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");



 

 

 

获取操作系统信息代码  
sigar 获取跨平台服务器信息

 

// 取到当前操作系统的名称 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_NONE break; 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()); }






版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215092.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:43
下一篇 2026年3月18日 下午2:43


相关推荐

  • 黑客常用命令大全

    黑客常用命令大全刚接触电脑的时候是从DOS系统开始,DOS时代根本就没有Windows这样的视窗操作界面,只有一个黑漆漆的窗口,让你输入命令。所以学DOS系统操作,cmd命令提示符是不可或缺的。可以告诉大家,大多数的程序员牛人或计算机专家在DOS系统下的操作是非常了得的,所以菜鸟要想成为计算机高手,DOS命令是非学不可。  直到今天的Windows系统,还是离不开DOS命令的操作。学习DOS系统操作,首先了解

    2022年7月15日
    19
  • 线性代数笔记 [4] —— 浅谈数域

    线性代数笔记 [4] —— 浅谈数域在学习高等代数的时候 我们经常可以在各种定义里看到看到 数域 两个字 但在后面的学习中这个概念似乎总是被轻描淡写的略过 似乎不是那么重要 实际上 可以这样说 不管是求解线性方程组还是矩阵的消元运算 计算中所考虑到的数集及其变化都处于数域内部 简而言之 整个过程是处于完全 封闭状态 的

    2026年3月17日
    1
  • java集合底层实现原理_java数据存入数组

    java集合底层实现原理_java数据存入数组modCount:记录当前集合被修改的次数在所有的集合实现类中(Collection与Map中),都会有一个 modCount 的变量出现,它的作用就是记录当前集合被修改的次数。下面以ArrayList 类进行说明:添加方法:删除方法:可以看出,两个操作都会影响元素的个数。 当我们使用迭代器或 foreach 遍历时,如果你在 foreach 遍历时,自动调用迭代器的迭代方法,此时在遍历过程中调用了集合的add,remove方法时,modCount就会改变,而迭代器记录的modCount

    2022年8月8日
    11
  • 125 Valid Palindrome

    125 Valid Palindrome

    2022年2月5日
    46
  • web端功能测试怎么测_web的主要功能是什么

    web端功能测试怎么测_web的主要功能是什么一、功能测试1.1链接测试链接是web应用系统的一个很重要的特征,主要是用于页面之间切换跳转,指导用户去一些不知道地址的页面的主要手段,链接测试一般关注三点:1)链接是否按照既定指示那样,确实链

    2022年8月1日
    12
  • 超详细pycharm安装教程

    超详细pycharm安装教程超详细pycharm安装教程第一步:双击运行pycharm安装程序更改安装路径第二步:全都不用勾选第三步:点击install第四步:出现如下界面表示正在安装第五步:勾选RunPycharm然后点击Finish第六步:第七步:点击右下角Next…第八步:点击右下角StartUsingPyCharm第九步:点击Evaluate试用第十步:点击Evaluate第十一步:点击+(加号)CreateNewProject第十二步:点击location

    2022年8月25日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号