一、背景:
現(xiàn)在在做項目的時候,經(jīng)常會遇到需要獲取這些信息,當不了解的時候會覺得很麻煩,事實上使用Sigar獲取相當?shù)暮唵?,今天我再根?jù)前人的總結(jié)再進行總結(jié)一下,解決一些使用Sigar會遇到的一些問題。
二、本文內(nèi)容:
a、Sigar的介紹與使用
b、介紹Sigar的零配置使用方法
三、核心內(nèi)容:
a、Sigard的介紹:
sigar全名是System Information Gatherer And Reporter,Sigar是Hyperic-hq產(chǎn)品的基礎包,是Hyperic HQ主要的數(shù)據(jù)收集組件。它用來從許多平臺收集系統(tǒng)和處理信息.
這些平臺包括:Linux, Windows, Solaris, AIX, HP-UX, FreeBSD and Mac OSX.
Sigar可以獲得系統(tǒng)的如下介個方面的信息:
1.操作系統(tǒng)的信息,包括:dataModel、cpuEndian、name、version、arch、machine、description、patchLevel、vendor、vendorVersion、vendorName、vendorCodeName
2.CPU信息,包括:基本信息(vendor、model、mhz、cacheSize)和統(tǒng)計信息(user、sys、idle、nice、wait)
3.內(nèi)存信息,物理內(nèi)存和交換內(nèi)存的總數(shù)、使用數(shù)、剩余數(shù);RAM的大小
4.進程信息,包括每個進程的內(nèi)存、CPU占用數(shù)、狀態(tài)、參數(shù)、句柄等。
5.文件系統(tǒng)信息,包括名稱、容量、剩余數(shù)、使用數(shù)、分區(qū)類型等
6.網(wǎng)絡接口信息,包括基本信息和統(tǒng)計信息。
7.網(wǎng)絡路由和鏈接表信息。
b、sigar的使用(介紹windows的方法,其它系統(tǒng)類似,只是依賴的文件不一致)
1、官網(wǎng)下載sigar(https://sourceforge.net/projects/sigar/download#!/sigar/1.6/hyperic-sigar-1.6.4.zip)
2、解壓文件,把文件sigar.jar提取出來,放入到你自己的系統(tǒng)中
3、把sigar-amd64-winnt.dll、sigar-x86-winnt.dll、sigar-x86-winnt.lib文件放入你的jdk文件夾的bin目錄下(或放入你的path環(huán)境變量里配置的任何一個地址下)
4、完成
一段經(jīng)典代碼(來源于http://blog.csdn.net/wudiazu/article/details/73829324)
package org.gocom.components.tool;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.Map;
import java.util.Properties;
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.Swap;
import org.hyperic.sigar.Who;
import com.eos.system.annotation.Bizlet;
public class RuntimeTest {
public static void main(String[] args) {
try {
SigarUtils s = new SigarUtils();
s.initSigar();
// System信息,從jvm獲取
property();
System.out.println("----------------------------------");
// cpu信息
cpu();
System.out.println("----------------------------------");
// 內(nèi)存信息
memory();
System.out.println("----------------------------------");
// 操作系統(tǒng)信息
os();
System.out.println("----------------------------------");
// 用戶信息
who();
System.out.println("----------------------------------");
// 文件系統(tǒng)信息
file();
System.out.println("----------------------------------");
// 網(wǎng)絡信息
net();
System.out.println("----------------------------------");
// 以太網(wǎng)信息
ethernet();
System.out.println("----------------------------------");
} catch (Exception e1) {
e1.printStackTrace();
}
}
private static void property() throws UnknownHostException {
Runtime r = Runtime.getRuntime();
Properties props = System.getProperties();
InetAddress addr;
addr = InetAddress.getLocalHost();
String ip = addr.getHostAddress();
Map<String, String> map = System.getenv();
String userName = map.get("USERNAME");// 獲取用戶名
String computerName = map.get("COMPUTERNAME");// 獲取計算機名
String userDomain = map.get("USERDOMAIN");// 獲取計算機域名
System.out.println("用戶名: " + userName);
System.out.println("計算機名: " + computerName);
System.out.println("計算機域名: " + userDomain);
System.out.println("本地ip地址: " + ip);
System.out.println("本地主機名: " + addr.getHostName());
System.out.println("JVM可以使用的總內(nèi)存: " + r.totalMemory());
System.out.println("JVM可以使用的剩余內(nèi)存: " + r.freeMemory());
System.out.println("JVM可以使用的處理器個數(shù): " + r.availableProcessors());
System.out.println("Java的運行環(huán)境版本: " + props.getProperty("java.version"));
System.out.println("Java的運行環(huán)境供應商: " + props.getProperty("java.vendor"));
System.out.println("Java供應商的URL: " + props.getProperty("java.vendor.url"));
System.out.println("Java的安裝路徑: " + props.getProperty("java.home"));
System.out.println("Java的虛擬機規(guī)范版本: " + props.getProperty("java.vm.specification.version"));
System.out.println("Java的虛擬機規(guī)范供應商: " + props.getProperty("java.vm.specification.vendor"));
System.out.println("Java的虛擬機規(guī)范名稱: " + props.getProperty("java.vm.specification.name"));
System.out.println("Java的虛擬機實現(xiàn)版本: " + props.getProperty("java.vm.version"));
System.out.println("Java的虛擬機實現(xiàn)供應商: " + props.getProperty("java.vm.vendor"));
System.out.println("Java的虛擬機實現(xiàn)名稱: " + props.getProperty("java.vm.name"));
System.out.println("Java運行時環(huán)境規(guī)范版本: " + props.getProperty("java.specification.version"));
System.out.println("Java運行時環(huán)境規(guī)范供應商: " + props.getProperty("java.specification.vender"));
System.out.println("Java運行時環(huán)境規(guī)范名稱: " + props.getProperty("java.specification.name"));
System.out.println("Java的類格式版本號: " + props.getProperty("java.class.version"));
System.out.println("Java的類路徑: " + props.getProperty("java.class.path"));
System.out.println("加載庫時搜索的路徑列表: " + props.getProperty("java.library.path"));
System.out.println("默認的臨時文件路徑: " + props.getProperty("java.io.tmpdir"));
System.out.println("一個或多個擴展目錄的路徑: " + props.getProperty("java.ext.dirs"));
System.out.println("操作系統(tǒng)的名稱: " + props.getProperty("os.name"));
System.out.println("操作系統(tǒng)的構(gòu)架: " + props.getProperty("os.arch"));
System.out.println("操作系統(tǒng)的版本: " + props.getProperty("os.version"));
System.out.println("文件分隔符: " + props.getProperty("file.separator"));
System.out.println("路徑分隔符: " + props.getProperty("path.separator"));
System.out.println("行分隔符: " + props.getProperty("line.separator"));
System.out.println("用戶的賬戶名稱: " + props.getProperty("user.name"));
System.out.println("用戶的主目錄: " + props.getProperty("user.home"));
System.out.println("用戶的當前工作目錄: " + props.getProperty("user.dir"));
}
@Bizlet("memory")
private static void memory() throws SigarException {
Sigar sigar = new Sigar();
Mem mem = sigar.getMem();
// 內(nèi)存總量
System.out.println("內(nèi)存總量: " + mem.getTotal() / 1024L + "K av");
// 當前內(nèi)存使用量
System.out.println("當前內(nèi)存使用量: " + mem.getUsed() / 1024L + "K used");
// 當前內(nèi)存剩余量
System.out.println("當前內(nèi)存剩余量: " + mem.getFree() / 1024L + "K free");
Swap swap = sigar.getSwap();
// 交換區(qū)總量
System.out.println("交換區(qū)總量: " + swap.getTotal() / 1024L + "K av");
// 當前交換區(qū)使用量
System.out.println("當前交換區(qū)使用量: " + swap.getUsed() / 1024L + "K used");
// 當前交換區(qū)剩余量
System.out.println("當前交換區(qū)剩余量: " + swap.getFree() / 1024L + "K free");
}
@Bizlet("cpu")
private static void cpu() throws SigarException {
Sigar sigar = new Sigar();
CpuInfo infos[] = sigar.getCpuInfoList();
CpuPerc cpuList[] = null;
cpuList = sigar.getCpuPercList();
for (int i = 0; i < infos.length; i++) {// 不管是單塊CPU還是多CPU都適用
CpuInfo info = infos[i];
System.out.println("第" + (i + 1) + "塊CPU信息");
System.out.println("CPU的總量MHz: " + info.getMhz());// CPU的總量MHz
System.out.println("CPU生產(chǎn)商: " + info.getVendor());// 獲得CPU的賣主,如:Intel
System.out.println("CPU類別: " + info.getModel());// 獲得CPU的類別,如:Celeron
System.out.println("CPU緩存數(shù)量: " + info.getCacheSize());// 緩沖存儲器數(shù)量
printCpuPerc(cpuList[i]);
}
}
private static void printCpuPerc(CpuPerc cpu) {
System.out.println("CPU用戶使用率: " + CpuPerc.format(cpu.getUser()));// 用戶使用率
System.out.println("CPU系統(tǒng)使用率: " + CpuPerc.format(cpu.getSys()));// 系統(tǒng)使用率
System.out.println("CPU當前等待率: " + CpuPerc.format(cpu.getWait()));// 當前等待率
System.out.println("CPU當前錯誤率: " + CpuPerc.format(cpu.getNice()));//
System.out.println("CPU當前空閑率: " + CpuPerc.format(cpu.getIdle()));// 當前空閑率
System.out.println("CPU總的使用率: " + CpuPerc.format(cpu.getCombined()));// 總的使用率
}
private static void os() {
OperatingSystem OS = OperatingSystem.getInstance();
// 操作系統(tǒng)內(nèi)核類型如: 386、486、586等x86
System.out.println("操作系統(tǒng): " + OS.getArch());
System.out.println("操作系統(tǒng)CpuEndian(): " + OS.getCpuEndian());//
System.out.println("操作系統(tǒng)DataModel(): " + OS.getDataModel());//
// 系統(tǒng)描述
System.out.println("操作系統(tǒng)的描述: " + OS.getDescription());
// 操作系統(tǒng)類型
// System.out.println("OS.getName(): " + OS.getName());
// System.out.println("OS.getPatchLevel(): " + OS.getPatchLevel());//
// 操作系統(tǒng)的賣主
System.out.println("操作系統(tǒng)的賣主: " + OS.getVendor());
// 賣主名稱
System.out.println("操作系統(tǒng)的賣主名: " + OS.getVendorCodeName());
// 操作系統(tǒng)名稱
System.out.println("操作系統(tǒng)名稱: " + OS.getVendorName());
// 操作系統(tǒng)賣主類型
System.out.println("操作系統(tǒng)賣主類型: " + OS.getVendorVersion());
// 操作系統(tǒng)的版本號
System.out.println("操作系統(tǒng)的版本號: " + OS.getVersion());
}
private static void who() throws SigarException {
Sigar sigar = new Sigar();
Who who[] = sigar.getWhoList();
if (who != null && who.length > 0) {
for (int i = 0; i < who.length; i++) {
// System.out.println("當前系統(tǒng)進程表中的用戶名" + String.valueOf(i));
Who _who = who[i];
System.out.println("用戶控制臺: " + _who.getDevice());
System.out.println("用戶host: " + _who.getHost());
// System.out.println("getTime(): " + _who.getTime());
// 當前系統(tǒng)進程表中的用戶名
System.out.println("當前系統(tǒng)進程表中的用戶名: " + _who.getUser());
}
}
}
private static void file() throws Exception {
Sigar sigar = new Sigar();
FileSystem fslist[] = sigar.getFileSystemList();
for (int i = 0; i < fslist.length; i++) {
System.out.println("分區(qū)的盤符名稱" + i);
FileSystem fs = fslist[i];
// 分區(qū)的盤符名稱
System.out.println("盤符名稱: " + fs.getDevName());
// 分區(qū)的盤符名稱
System.out.println("盤符路徑: " + fs.getDirName());
System.out.println("盤符標志: " + fs.getFlags());//
// 文件系統(tǒng)類型,比如 FAT32、NTFS
System.out.println("盤符類型: " + fs.getSysTypeName());
// 文件系統(tǒng)類型名,比如本地硬盤、光驅(qū)、網(wǎng)絡文件系統(tǒng)等
System.out.println("盤符類型名: " + fs.getTypeName());
// 文件系統(tǒng)類型
System.out.println("盤符文件系統(tǒng)類型: " + fs.getType());
FileSystemUsage usage = null;
usage = sigar.getFileSystemUsage(fs.getDirName());
switch (fs.getType()) {
case 0: // TYPE_UNKNOWN :未知
break;
case 1: // TYPE_NONE
break;
case 2: // TYPE_LOCAL_DISK : 本地硬盤
// 文件系統(tǒng)總大小
System.out.println(fs.getDevName() + "總大小: " + usage.getTotal() + "KB");
// 文件系統(tǒng)剩余大小
System.out.println(fs.getDevName() + "剩余大小: " + usage.getFree() + "KB");
// 文件系統(tǒng)可用大小
System.out.println(fs.getDevName() + "可用大小: " + usage.getAvail() + "KB");
// 文件系統(tǒng)已經(jīng)使用量
System.out.println(fs.getDevName() + "已經(jīng)使用量: " + usage.getUsed() + "KB");
double usePercent = usage.getUsePercent() * 100D;
// 文件系統(tǒng)資源的利用率
System.out.println(fs.getDevName() + "資源的利用率: " + usePercent + "%");
break;
case 3:// TYPE_NETWORK :網(wǎng)絡
break;
case 4:// TYPE_RAM_DISK :閃存
break;
case 5:// TYPE_CDROM :光驅(qū)
break;
case 6:// TYPE_SWAP :頁面交換
break;
}
System.out.println(fs.getDevName() + "讀出: " + usage.getDiskReads());
System.out.println(fs.getDevName() + "寫入: " + usage.getDiskWrites());
}
return;
}
private static void net() 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);
System.out.println("網(wǎng)絡設備名: " + name);// 網(wǎng)絡設備名
System.out.println("IP地址: " + ifconfig.getAddress());// IP地址
System.out.println("子網(wǎng)掩碼: " + ifconfig.getNetmask());// 子網(wǎng)掩碼
if ((ifconfig.getFlags() & 1L) <= 0L) {
System.out.println("!IFF_UP...skipping getNetInterfaceStat");
continue;
}
NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
System.out.println(name + "接收的總包裹數(shù):" + ifstat.getRxPackets());// 接收的總包裹數(shù)
System.out.println(name + "發(fā)送的總包裹數(shù):" + ifstat.getTxPackets());// 發(fā)送的總包裹數(shù)
System.out.println(name + "接收到的總字節(jié)數(shù):" + ifstat.getRxBytes());// 接收到的總字節(jié)數(shù)
System.out.println(name + "發(fā)送的總字節(jié)數(shù):" + ifstat.getTxBytes());// 發(fā)送的總字節(jié)數(shù)
System.out.println(name + "接收到的錯誤包數(shù):" + ifstat.getRxErrors());// 接收到的錯誤包數(shù)
System.out.println(name + "發(fā)送數(shù)據(jù)包時的錯誤數(shù):" + ifstat.getTxErrors());// 發(fā)送數(shù)據(jù)包時的錯誤數(shù)
System.out.println(name + "接收時丟棄的包數(shù):" + ifstat.getRxDropped());// 接收時丟棄的包數(shù)
System.out.println(name + "發(fā)送時丟棄的包數(shù):" + ifstat.getTxDropped());// 發(fā)送時丟棄的包數(shù)
}
}
private static void ethernet() throws SigarException {
Sigar sigar = null;
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.getName() + "IP地址:" + cfg.getAddress());// IP地址
System.out.println(cfg.getName() + "網(wǎng)關廣播地址:" + cfg.getBroadcast());// 網(wǎng)關廣播地址
System.out.println(cfg.getName() + "網(wǎng)卡MAC地址:" + cfg.getHwaddr());// 網(wǎng)卡MAC地址
System.out.println(cfg.getName() + "子網(wǎng)掩碼:" + cfg.getNetmask());// 子網(wǎng)掩碼
System.out.println(cfg.getName() + "網(wǎng)卡描述信息:" + cfg.getDescription());// 網(wǎng)卡描述信息
System.out.println(cfg.getName() + "網(wǎng)卡類型" + cfg.getType());//
}
}
}
運行此代碼,結(jié)果如下
用戶名: caililiang
計算機名: CAILILIANG-PC
計算機域名: caililiang-PC
本地ip地址: 192.168.43.210
本地主機名: caililiang-PC
JVM可以使用的總內(nèi)存: 62586880
JVM可以使用的剩余內(nèi)存: 57015440
JVM可以使用的處理器個數(shù): 4
Java的運行環(huán)境版本: 1.6.0_45
Java的運行環(huán)境供應商: Sun Microsystems Inc.
Java供應商的URL: http://java.sun.com/
Java的安裝路徑: C:\primeton\platform5\ide\eclipse\jre\jre
Java的虛擬機規(guī)范版本: 1.0
Java的虛擬機規(guī)范供應商: Sun Microsystems Inc.
Java的虛擬機規(guī)范名稱: Java Virtual Machine Specification
Java的虛擬機實現(xiàn)版本: 20.45-b01
Java的虛擬機實現(xiàn)供應商: Sun Microsystems Inc.
Java的虛擬機實現(xiàn)名稱: Java HotSpot(TM) 64-Bit Server VM
Java運行時環(huán)境規(guī)范版本: 1.6
Java運行時環(huán)境規(guī)范供應商: null
Java運行時環(huán)境規(guī)范名稱: Java Platform API Specification
Java的類格式版本號: 50.0
Java的類路徑: (太長,剪掉了)
默認的臨時文件路徑: C:\Users\CAILIL~1\AppData\Local\Temp\
一個或多個擴展目錄的路徑: C:\primeton\platform5\ide\eclipse\jre\jre\lib\ext;C:\Windows\Sun\Java\lib\ext
操作系統(tǒng)的名稱: Windows 7
操作系統(tǒng)的構(gòu)架: amd64
操作系統(tǒng)的版本: 6.1
文件分隔符: \
路徑分隔符: ;
行分隔符:
用戶的賬戶名稱: caililiang
用戶的主目錄: C:\Users\caililiang
用戶的當前工作目錄: C:\primeton\platform5\ide\eclipse\workspace\DQMS
----------------------------------
第1塊CPU信息
CPU的總量MHz: 2394
CPU生產(chǎn)商: Intel
CPU類別: Core(TM) i3-3110M CPU @ 2.40GHz
CPU緩存數(shù)量: -1
CPU用戶使用率: 12.4%
CPU系統(tǒng)使用率: 3.2%
CPU當前等待率: 0.0%
CPU當前錯誤率: 0.0%
CPU當前空閑率: 84.3%
CPU總的使用率: 15.6%
第2塊CPU信息
CPU的總量MHz: 2394
CPU生產(chǎn)商: Intel
CPU類別: Core(TM) i3-3110M CPU @ 2.40GHz
CPU緩存數(shù)量: -1
CPU用戶使用率: 0.0%
CPU系統(tǒng)使用率: 0.0%
CPU當前等待率: 0.0%
CPU當前錯誤率: 0.0%
CPU當前空閑率: 100.0%
CPU總的使用率: 0.0%
第3塊CPU信息
CPU的總量MHz: 2394
CPU生產(chǎn)商: Intel
CPU類別: Core(TM) i3-3110M CPU @ 2.40GHz
CPU緩存數(shù)量: -1
CPU用戶使用率: 9.2%
CPU系統(tǒng)使用率: 3.2%
CPU當前等待率: 0.0%
CPU當前錯誤率: 0.0%
CPU當前空閑率: 87.5%
CPU總的使用率: 12.4%
第4塊CPU信息
CPU的總量MHz: 2394
CPU生產(chǎn)商: Intel
CPU類別: Core(TM) i3-3110M CPU @ 2.40GHz
CPU緩存數(shù)量: -1
CPU用戶使用率: 0.0%
CPU系統(tǒng)使用率: 0.0%
CPU當前等待率: 0.0%
CPU當前錯誤率: 0.0%
CPU當前空閑率: 100.0%
CPU總的使用率: 0.0%
----------------------------------
內(nèi)存總量: 4077252K av
當前內(nèi)存使用量: 2867208K used
當前內(nèi)存剩余量: 1210044K free
交換區(qū)總量: 8152644K av
當前交換區(qū)使用量: 5345996K used
當前交換區(qū)剩余量: 2806648K free
----------------------------------
操作系統(tǒng): x64
操作系統(tǒng)CpuEndian(): little
操作系統(tǒng)DataModel(): 64
操作系統(tǒng)的描述: Microsoft Windows 7
操作系統(tǒng)的賣主: Microsoft
操作系統(tǒng)的賣主名: Vienna
操作系統(tǒng)名稱: Windows 7
操作系統(tǒng)賣主類型: 7
操作系統(tǒng)的版本號: 6.1
----------------------------------
用戶控制臺: console
用戶host: NT AUTHORITY
當前系統(tǒng)進程表中的用戶名: LOCAL SERVICE
用戶控制臺: console
用戶host: NT AUTHORITY
當前系統(tǒng)進程表中的用戶名: NETWORK SERVICE
用戶控制臺: console
用戶host: caililiang-PC
當前系統(tǒng)進程表中的用戶名: caililiang
用戶控制臺: console
用戶host: NT SERVICE
當前系統(tǒng)進程表中的用戶名: MSSQLSERVER
用戶控制臺: console
用戶host: NT AUTHORITY
當前系統(tǒng)進程表中的用戶名: SYSTEM
----------------------------------
分區(qū)的盤符名稱0
盤符名稱: C:\
盤符路徑: C:\
盤符標志: 0
盤符類型: NTFS
盤符類型名: local
盤符文件系統(tǒng)類型: 2
C:\總大小: 117219324KB
C:\剩余大小: 3883336KB
C:\可用大小: 3883336KB
C:\已經(jīng)使用量: 113335988KB
C:\資源的利用率: 97.0%
C:\讀出: 430422
C:\寫入: 98924
分區(qū)的盤符名稱1
盤符名稱: D:\
盤符路徑: D:\
盤符標志: 0
盤符類型: NTFS
盤符類型名: local
盤符文件系統(tǒng)類型: 2
D:\總大小: 106920572KB
D:\剩余大小: 20250824KB
D:\可用大小: 20250824KB
D:\已經(jīng)使用量: 86669748KB
D:\資源的利用率: 82.0%
D:\讀出: 94198
D:\寫入: 23002
分區(qū)的盤符名稱2
盤符名稱: E:\
盤符路徑: E:\
盤符標志: 0
盤符類型: NTFS
盤符類型名: local
盤符文件系統(tǒng)類型: 2
E:\總大小: 105635372KB
E:\剩余大小: 7226036KB
E:\可用大小: 7226036KB
E:\已經(jīng)使用量: 98409336KB
E:\資源的利用率: 94.0%
E:\讀出: 29
E:\寫入: 816
分區(qū)的盤符名稱3
盤符名稱: F:\
盤符路徑: F:\
盤符標志: 0
盤符類型: NTFS
盤符類型名: local
盤符文件系統(tǒng)類型: 2
F:\總大小: 168152320KB
F:\剩余大小: 24331392KB
F:\可用大小: 24331392KB
F:\已經(jīng)使用量: 143820928KB
F:\資源的利用率: 86.0%
F:\讀出: 22
F:\寫入: 676
----------------------------------
網(wǎng)絡設備名: eth0
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth0接收的總包裹數(shù):0
eth0發(fā)送的總包裹數(shù):0
eth0接收到的總字節(jié)數(shù):0
eth0發(fā)送的總字節(jié)數(shù):0
eth0接收到的錯誤包數(shù):0
eth0發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth0接收時丟棄的包數(shù):0
eth0發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth1
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth1接收的總包裹數(shù):0
eth1發(fā)送的總包裹數(shù):0
eth1接收到的總字節(jié)數(shù):0
eth1發(fā)送的總字節(jié)數(shù):0
eth1接收到的錯誤包數(shù):0
eth1發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth1接收時丟棄的包數(shù):0
eth1發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth2
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth3
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth4
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth4接收的總包裹數(shù):0
eth4發(fā)送的總包裹數(shù):0
eth4接收到的總字節(jié)數(shù):0
eth4發(fā)送的總字節(jié)數(shù):0
eth4接收到的錯誤包數(shù):0
eth4發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth4接收時丟棄的包數(shù):0
eth4發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth5
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth5接收的總包裹數(shù):0
eth5發(fā)送的總包裹數(shù):0
eth5接收到的總字節(jié)數(shù):0
eth5發(fā)送的總字節(jié)數(shù):0
eth5接收到的錯誤包數(shù):0
eth5發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth5接收時丟棄的包數(shù):0
eth5發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth6
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth7
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth8
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth8接收的總包裹數(shù):0
eth8發(fā)送的總包裹數(shù):0
eth8接收到的總字節(jié)數(shù):0
eth8發(fā)送的總字節(jié)數(shù):0
eth8接收到的錯誤包數(shù):0
eth8發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth8接收時丟棄的包數(shù):0
eth8發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth9
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth9接收的總包裹數(shù):0
eth9發(fā)送的總包裹數(shù):0
eth9接收到的總字節(jié)數(shù):0
eth9發(fā)送的總字節(jié)數(shù):0
eth9接收到的錯誤包數(shù):0
eth9發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth9接收時丟棄的包數(shù):0
eth9發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth10
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth11
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: lo0
IP地址: 127.0.0.1
子網(wǎng)掩碼: 255.0.0.0
lo0接收的總包裹數(shù):0
lo0發(fā)送的總包裹數(shù):0
lo0接收到的總字節(jié)數(shù):0
lo0發(fā)送的總字節(jié)數(shù):0
lo0接收到的錯誤包數(shù):0
lo0發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
lo0接收時丟棄的包數(shù):0
lo0發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth12
IP地址: 192.168.43.210
子網(wǎng)掩碼: 255.255.255.0
eth12接收的總包裹數(shù):148748
eth12發(fā)送的總包裹數(shù):45272
eth12接收到的總字節(jié)數(shù):205564111
eth12發(fā)送的總字節(jié)數(shù):4224624
eth12接收到的錯誤包數(shù):0
eth12發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth12接收時丟棄的包數(shù):0
eth12發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth13
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth13接收的總包裹數(shù):148748
eth13發(fā)送的總包裹數(shù):45272
eth13接收到的總字節(jié)數(shù):205564111
eth13發(fā)送的總字節(jié)數(shù):4224624
eth13接收到的錯誤包數(shù):0
eth13發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth13接收時丟棄的包數(shù):0
eth13發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth14
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth14接收的總包裹數(shù):148748
eth14發(fā)送的總包裹數(shù):45272
eth14接收到的總字節(jié)數(shù):205564111
eth14發(fā)送的總字節(jié)數(shù):4224624
eth14接收到的錯誤包數(shù):0
eth14發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth14接收時丟棄的包數(shù):0
eth14發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth15
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth15接收的總包裹數(shù):148748
eth15發(fā)送的總包裹數(shù):45272
eth15接收到的總字節(jié)數(shù):205564111
eth15發(fā)送的總字節(jié)數(shù):4224624
eth15接收到的錯誤包數(shù):0
eth15發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth15接收時丟棄的包數(shù):0
eth15發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth16
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
eth16接收的總包裹數(shù):148748
eth16發(fā)送的總包裹數(shù):45272
eth16接收到的總字節(jié)數(shù):205564111
eth16發(fā)送的總字節(jié)數(shù):4224624
eth16接收到的錯誤包數(shù):0
eth16發(fā)送數(shù)據(jù)包時的錯誤數(shù):0
eth16接收時丟棄的包數(shù):0
eth16發(fā)送時丟棄的包數(shù):0
網(wǎng)絡設備名: eth17
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth18
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth19
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
網(wǎng)絡設備名: eth20
IP地址: 0.0.0.0
子網(wǎng)掩碼: 0.0.0.0
!IFF_UP...skipping getNetInterfaceStat
----------------------------------
eth0IP地址:0.0.0.0
eth0網(wǎng)關廣播地址:0.0.0.0
eth0網(wǎng)卡MAC地址:F0:7E:20:52:41:53
eth0子網(wǎng)掩碼:0.0.0.0
eth0網(wǎng)卡描述信息:WAN Miniport (IPv6)
eth0網(wǎng)卡類型Ethernet
eth1IP地址:0.0.0.0
eth1網(wǎng)關廣播地址:0.0.0.0
eth1網(wǎng)卡MAC地址:EE:1F:20:52:41:53
eth1子網(wǎng)掩碼:0.0.0.0
eth1網(wǎng)卡描述信息:WAN Miniport (Network Monitor)
eth1網(wǎng)卡類型Ethernet
eth2IP地址:0.0.0.0
eth2網(wǎng)關廣播地址:0.0.0.0
eth2網(wǎng)卡MAC地址:74:D0:2B:D8:68:14
eth2子網(wǎng)掩碼:0.0.0.0
eth2網(wǎng)卡描述信息:Realtek PCIe GBE Family Controller-QoS Packet Scheduler-0000
eth2網(wǎng)卡類型Ethernet
eth3IP地址:0.0.0.0
eth3網(wǎng)關廣播地址:0.0.0.0
eth3網(wǎng)卡MAC地址:74:D0:2B:D8:68:14
eth3子網(wǎng)掩碼:0.0.0.0
eth3網(wǎng)卡描述信息:Realtek PCIe GBE Family Controller-WFP LightWeight Filter-0000
eth3網(wǎng)卡類型Ethernet
eth4IP地址:0.0.0.0
eth4網(wǎng)關廣播地址:0.0.0.0
eth4網(wǎng)卡MAC地址:EE:1F:20:52:41:53
eth4子網(wǎng)掩碼:0.0.0.0
eth4網(wǎng)卡描述信息:WAN Miniport (IP)
eth4網(wǎng)卡類型Ethernet
eth5IP地址:0.0.0.0
eth5網(wǎng)關廣播地址:0.0.0.0
eth5網(wǎng)卡MAC地址:EE:1F:20:52:41:53
eth5子網(wǎng)掩碼:0.0.0.0
eth5網(wǎng)卡描述信息:WAN Miniport (Network Monitor)-QoS Packet Scheduler-0000
eth5網(wǎng)卡類型Ethernet
eth6IP地址:0.0.0.0
eth6網(wǎng)關廣播地址:0.0.0.0
eth6網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C4
eth6子網(wǎng)掩碼:0.0.0.0
eth6網(wǎng)卡描述信息:Bluetooth é豸(??è???óòí?
eth6網(wǎng)卡類型Ethernet
eth7IP地址:0.0.0.0
eth7網(wǎng)關廣播地址:0.0.0.0
eth7網(wǎng)卡MAC地址:86:D4:1B:4E:40:F9
eth7子網(wǎng)掩碼:0.0.0.0
eth7網(wǎng)卡描述信息:Remote NDIS based Internet Sharing Device
eth7網(wǎng)卡類型Ethernet
eth8IP地址:0.0.0.0
eth8網(wǎng)關廣播地址:0.0.0.0
eth8網(wǎng)卡MAC地址:EE:1F:20:52:41:53
eth8子網(wǎng)掩碼:0.0.0.0
eth8網(wǎng)卡描述信息:WAN Miniport (IP)-QoS Packet Scheduler-0000
eth8網(wǎng)卡類型Ethernet
eth9IP地址:0.0.0.0
eth9網(wǎng)關廣播地址:0.0.0.0
eth9網(wǎng)卡MAC地址:F0:7E:20:52:41:53
eth9子網(wǎng)掩碼:0.0.0.0
eth9網(wǎng)卡描述信息:WAN Miniport (IPv6)-QoS Packet Scheduler-0000
eth9網(wǎng)卡類型Ethernet
eth10IP地址:0.0.0.0
eth10網(wǎng)關廣播地址:0.0.0.0
eth10網(wǎng)卡MAC地址:74:D0:2B:D8:68:14
eth10子網(wǎng)掩碼:0.0.0.0
eth10網(wǎng)卡描述信息:Realtek PCIe GBE Family Controller
eth10網(wǎng)卡類型Ethernet
eth11IP地址:0.0.0.0
eth11網(wǎng)關廣播地址:0.0.0.0
eth11網(wǎng)卡MAC地址:F6:2D:AF:61:77:8C
eth11子網(wǎng)掩碼:0.0.0.0
eth11網(wǎng)卡描述信息:Remote NDIS based Internet Sharing Device #2
eth11網(wǎng)卡類型Ethernet
eth12IP地址:192.168.43.210
eth12網(wǎng)關廣播地址:192.168.43.255
eth12網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C5
eth12子網(wǎng)掩碼:255.255.255.0
eth12網(wǎng)卡描述信息:Qualcomm Atheros AR9485WB-EG Wireless Network Adapter
eth12網(wǎng)卡類型Ethernet
eth13IP地址:0.0.0.0
eth13網(wǎng)關廣播地址:0.0.0.0
eth13網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C5
eth13子網(wǎng)掩碼:0.0.0.0
eth13網(wǎng)卡描述信息:Qualcomm Atheros AR9485WB-EG Wireless Network Adapter-Virtual WiFi Filter Driver-0000
eth13網(wǎng)卡類型Ethernet
eth14IP地址:0.0.0.0
eth14網(wǎng)關廣播地址:0.0.0.0
eth14網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C5
eth14子網(wǎng)掩碼:0.0.0.0
eth14網(wǎng)卡描述信息:Qualcomm Atheros AR9485WB-EG Wireless Network Adapter-QoS Packet Scheduler-0000
eth14網(wǎng)卡類型Ethernet
eth15IP地址:0.0.0.0
eth15網(wǎng)關廣播地址:0.0.0.0
eth15網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C5
eth15子網(wǎng)掩碼:0.0.0.0
eth15網(wǎng)卡描述信息:Qualcomm Atheros AR9485WB-EG Wireless Network Adapter-Native WiFi Filter Driver-0000
eth15網(wǎng)卡類型Ethernet
eth16IP地址:0.0.0.0
eth16網(wǎng)關廣播地址:0.0.0.0
eth16網(wǎng)卡MAC地址:6C:71:D9:AC:DD:C5
eth16子網(wǎng)掩碼:0.0.0.0
eth16網(wǎng)卡描述信息:Qualcomm Atheros AR9485WB-EG Wireless Network Adapter-WFP LightWeight Filter-0000
eth16網(wǎng)卡類型Ethernet
eth17IP地址:0.0.0.0
eth17網(wǎng)關廣播地址:0.0.0.0
eth17網(wǎng)卡MAC地址:1E:71:D9:AC:DD:C5
eth17子網(wǎng)掩碼:0.0.0.0
eth17網(wǎng)卡描述信息:Microsoft Virtual WiFi Miniport Adapter-Native WiFi Filter Driver-0000
eth17網(wǎng)卡類型Ethernet
eth18IP地址:0.0.0.0
eth18網(wǎng)關廣播地址:0.0.0.0
eth18網(wǎng)卡MAC地址:1E:71:D9:AC:DD:C5
eth18子網(wǎng)掩碼:0.0.0.0
eth18網(wǎng)卡描述信息:Microsoft Virtual WiFi Miniport Adapter
eth18網(wǎng)卡類型Ethernet
eth19IP地址:0.0.0.0
eth19網(wǎng)關廣播地址:0.0.0.0
eth19網(wǎng)卡MAC地址:1E:71:D9:AC:DD:C5
eth19子網(wǎng)掩碼:0.0.0.0
eth19網(wǎng)卡描述信息:Microsoft Virtual WiFi Miniport Adapter-QoS Packet Scheduler-0000
eth19網(wǎng)卡類型Ethernet
eth20IP地址:0.0.0.0
eth20網(wǎng)關廣播地址:0.0.0.0
eth20網(wǎng)卡MAC地址:1E:71:D9:AC:DD:C5
eth20子網(wǎng)掩碼:0.0.0.0
eth20網(wǎng)卡描述信息:Microsoft Virtual WiFi Miniport Adapter-WFP LightWeight Filter-0000
eth20網(wǎng)卡類型Ethernet
----------------------------------
c、sigar的零配置使用
看到這里,大家應該有疑問了,就是我們在開發(fā)一個系統(tǒng)后,是要盡量減少用戶的配置的,就算要做配置,也是一些很簡單的配置,而上面的描述是要找path路徑配置,又要拷貝文件,這個操作對于用戶來說是非常的麻煩,用戶肯定不愿意接受的,但上面的配置又必須存在,所以我們要想辦法解決這個問題
其實這個問題解決起來也是比較簡單,通過上面的“Sigar的使用”的介紹,大家就應該可以理解到,我們拷貝文件到對應的目錄,只不過就是為了讓java虛擬機可以找到這幾個文件,所以我們干脆就把這幾個文件放入到我們的系統(tǒng)的某個文件夾下,然后再通過代碼把對應的文件夾路徑配置到Path路徑下,這樣就解決了配置的問題,具體做法如下
package org.gocom.components.tool;
import java.io.File;
import org.hyperic.sigar.Sigar;
public class SigarUtils {
//public final static Sigar sigar = initSigar();
public static Sigar initSigar() {
try {
//此處只為得到依賴庫文件的目錄,可根據(jù)實際項目自定義
//String file = Paths.get(PathKit.getWebRootPath(), "files", "sigar",".sigar_shellrc").toString();
//File classPath = new File(file).getParentFile();
//String filePath = SigarUtils.class.getClassLoader().getResource("").toURI().getPath();
//System.out.println(filePath);
File classPath = new File("C:/primeton/platform6/ide/eclipse/workspace/ywlcyz/src/org/gocom/components/test/sigar");//這里我直接把文件路徑寫死了
String path = System.getProperty("java.library.path");
String sigarLibPath = classPath.getCanonicalPath();
//為防止java.library.path重復加,此處判斷了一下
if (!path.contains(sigarLibPath)) {
if (isOSWin()) {
path += ";" + sigarLibPath;System.out.println(path);
} else {
path += ":" + sigarLibPath;
}
System.setProperty("java.library.path", path);
}
return new Sigar();
} catch (Exception e) {
return null;
}
}
public static boolean isOSWin(){//OS 版本判斷
String OS = System.getProperty("os.name").toLowerCase();
if (OS.indexOf("win") >= 0) {
return true;
} else return false;
}
}
通過如下代碼初始化Sigar環(huán)境,然后再使用Sigar,就不用再進行配置了。
如有問題或有想相互學習交流的,可以聯(lián)系本人(郵箱:18986837482@163.com,微信:caililiangcaililiang,QQ:785553790)