java使用siger 获取服务器硬件信息(CPU 内存 网络 io等)

java使用siger 获取服务器硬件信息(CPU 内存 网络 io等)java 使用 siger 获取服务器硬件信息 CPU 内存网络 io 等

java使用siger 获取服务器硬件信息(CPU 内存 网络 io等)

通过使用第三方开源jar包sigar.jar我们可以获得本地的信息

1.下载sigar.jar

2.按照主页上的说明解压包后将相应的文件copy到java路径。比如windows32位操作系统需要将lib中sigar-x86-winnt.dll文件拷贝到java SDK目录的bin内

参考官方主页上的配置项。

 

File Language Description Required
sigar.jar Java Java API Yes (for Java only)
log4j.jar Java Java logging API No
libsigar-x86-linux.so C Linux AMD/Intel 32-bit *
libsigar-amd64-linux.so C Linux AMD/Intel 64-bit *
libsigar-ppc-linux.so C Linux PowerPC 32-bit *
libsigar-ppc64-linux.so C Linux PowerPC 64-bit *
libsigar-ia64-linux.so C Linux Itanium 64-bit *
libsigar-s390x-linux.so C Linux zSeries 64-bit *
sigar-x86-winnt.dll C Windows AMD/Intel 32-bit *
sigar-amd64-winnt.dll C Windows AMD/Intel 64-bit *
libsigar-ppc-aix-5.so C AIX PowerPC 32-bit *
libsigar-ppc64-aix-5.so C AIX PowerPC 64-bit *
libsigar-pa-hpux-11.sl C HP-UX PA-RISC 32-bit *
libsigar-ia64-hpux-11.sl C HP-UX Itanium 64-bt *
libsigar-sparc-solaris.so C Solaris Sparc 32-bit *
libsigar-sparc64-solaris.so C Solaris Sparc 64-bit *
libsigar-x86-solaris.so C Solaris AMD/Intel 32-bit *
libsigar-amd64-solaris.so C Solaris AMD/Intel 64-bit *
libsigar-universal-macosx.dylib C Mac OS X PowerPC/Intel 32-bit *
libsigar-universal64-macosx.dylib C Mac OS X PowerPC/Intel 64-bit *
libsigar-x86-freebsd-5.so C FreeBSD 5.x AMD/Intel 32-bit *
libsigar-x86-freebsd-6.so C FreeBSD 6.x AMD/Intel 64-bit *
libsigar-amd64-freebsd-6.so C FreeBSD 6.x AMD/Intel 64-bit *

 

3.代码实现

 示例java项目下载地址:http://download.csdn.net/detail/jifeng3518/

复制代码
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;

public  class RuntimeTest {
     public  static  void main(String[] args) {
         try {
             //  System信息,从jvm获取

            property();
            System.out.println(“———————————-“);
             //  cpu信息

            cpu();
            System.out.println(“———————————-“);
             //  内存信息

            memory();
            System.out.println(“———————————-“);
             //  操作系统信息

            os();
            System.out.println(“———————————-“);
             //  用户信息

            who();
            System.out.println(“———————————-“);
             //  文件系统信息

            file();
            System.out.println(“———————————-“);
             //  网络信息

            net();
            System.out.println(“———————————-“);
             //  以太网信息

            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

 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可以使用的总内存:    ” + r.totalMemory());
        System.out.println(“JVM可以使用的剩余内存:    ” + r.freeMemory());
        System.out.println(“JVM可以使用的处理器个数:    ” + r.availableProcessors());
        System.out.println(“Java的运行环境版本:    ” + props.getProperty(“java.version”));
        System.out.println(“Java的运行环境供应商:    ” + 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的虚拟机规范版本:    ” + props.getProperty(“java.vm.specification.version”));
        System.out.println(“Java的虚拟机规范供应商:    ” + props.getProperty(“java.vm.specification.vendor”));
        System.out.println(“Java的虚拟机规范名称:    ” + props.getProperty(“java.vm.specification.name”));
        System.out.println(“Java的虚拟机实现版本:    ” + props.getProperty(“java.vm.version”));
        System.out.println(“Java的虚拟机实现供应商:    ” + props.getProperty(“java.vm.vendor”));
        System.out.println(“Java的虚拟机实现名称:    ” + props.getProperty(“java.vm.name”));
        System.out.println(“Java运行时环境规范版本:    ” + props.getProperty(“java.specification.version”));
        System.out.println(“Java运行时环境规范供应商:    ” + props.getProperty(“java.specification.vender”));
        System.out.println(“Java运行时环境规范名称:    ” + 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(“操作系统的名称:    ” + props.getProperty(“os.name”));
        System.out.println(“操作系统的构架:    ” + props.getProperty(“os.arch”));
        System.out.println(“操作系统的版本:    ” + 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”));
    }

     private  static  void memory()  throws SigarException {
        Sigar sigar =  new Sigar();
        Mem mem = sigar.getMem();
         //  内存总量

        System.out.println(“内存总量:    ” + mem.getTotal() / 1024L + “K av”);
         //  当前内存使用量

        System.out.println(“当前内存使用量:    ” + mem.getUsed() / 1024L + “K used”);
         //  当前内存剩余量

        System.out.println(“当前内存剩余量:    ” + mem.getFree() / 1024L + “K free”);
        Swap swap = sigar.getSwap();
         //  交换区总量

        System.out.println(“交换区总量:    ” + swap.getTotal() / 1024L + “K av”);
         //  当前交换区使用量

        System.out.println(“当前交换区使用量:    ” + swap.getUsed() / 1024L + “K used”);
         //  当前交换区剩余量

        System.out.println(“当前交换区剩余量:    ” + swap.getFree() / 1024L + “K free”);
    }

     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生产商:    ” + info.getVendor()); //  获得CPU的卖主,如:Intel

            System.out.println(“CPU类别:    ” + info.getModel()); //  获得CPU的类别,如:Celeron

            System.out.println(“CPU缓存数量:    ” + info.getCacheSize()); //  缓冲存储器数量

            printCpuPerc(cpuList[i]);
        }
    }

     private  static  void printCpuPerc(CpuPerc cpu) {
        System.out.println(“CPU用户使用率:    ” + CpuPerc.format(cpu.getUser())); //  用户使用率

        System.out.println(“CPU系统使用率:    ” + CpuPerc.format(cpu.getSys())); //  系统使用率

        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();
         //  操作系统内核类型如: 386、486、586等x86

        System.out.println(“操作系统:    ” + OS.getArch());
        System.out.println(“操作系统CpuEndian():    ” + OS.getCpuEndian()); //

        System.out.println(“操作系统DataModel():    ” + OS.getDataModel()); //
        
//  系统描述

        System.out.println(“操作系统的描述:    ” + OS.getDescription());
         //  操作系统类型
        
//  System.out.println(“OS.getName():    ” + OS.getName());
        
//  System.out.println(“OS.getPatchLevel():    ” + OS.getPatchLevel()); //
        
//  操作系统的卖主

        System.out.println(“操作系统的卖主:    ” + OS.getVendor());
         //  卖主名称

        System.out.println(“操作系统的卖主名:    ” + OS.getVendorCodeName());
         //  操作系统名称

        System.out.println(“操作系统名称:    ” + OS.getVendorName());
         //  操作系统卖主类型

        System.out.println(“操作系统卖主类型:    ” + OS.getVendorVersion());
         //  操作系统的版本号

        System.out.println(“操作系统的版本号:    ” + 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(“当前系统进程表中的用户名” + String.valueOf(i));

                Who _who = who[i];
                System.out.println(“用户控制台:    ” + _who.getDevice());
                System.out.println(“用户host:    ” + _who.getHost());
                 //  System.out.println(“getTime():    ” + _who.getTime());
                
//  当前系统进程表中的用户名

                System.out.println(“当前系统进程表中的用户名:    ” + _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(“分区的盘符名称” + i);
            FileSystem fs = fslist[i];
             //  分区的盘符名称

            System.out.println(“盘符名称:    ” + fs.getDevName());
             //  分区的盘符名称

            System.out.println(“盘符路径:    ” + fs.getDirName());
            System.out.println(“盘符标志:    ” + fs.getFlags()); //
            
//  文件系统类型,比如 FAT32、NTFS

            System.out.println(“盘符类型:    ” + fs.getSysTypeName());
             //  文件系统类型名,比如本地硬盘、光驱、网络文件系统等

            System.out.println(“盘符类型名:    ” + fs.getTypeName());
             //  文件系统类型

            System.out.println(“盘符文件系统类型:    ” + 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 : 本地硬盘
                
//  文件系统总大小

                System.out.println(fs.getDevName() + “总大小:    ” + usage.getTotal() + “KB”);
                 //  文件系统剩余大小

                System.out.println(fs.getDevName() + “剩余大小:    ” + usage.getFree() + “KB”);
                 //  文件系统可用大小

                System.out.println(fs.getDevName() + “可用大小:    ” + usage.getAvail() + “KB”);
                 //  文件系统已经使用量

                System.out.println(fs.getDevName() + “已经使用量:    ” + usage.getUsed() + “KB”);
                 double usePercent = usage.getUsePercent() * 100D;
                 //  文件系统资源的利用率

                System.out.println(fs.getDevName() + “资源的利用率:    ” + 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(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(“网络设备名:    ” + name); //  网络设备名

            System.out.println(“IP地址:    ” + ifconfig.getAddress()); //  IP地址

            System.out.println(“子网掩码:    ” + ifconfig.getNetmask()); //  子网掩码

             if ((ifconfig.getFlags() & 1L) <= 0L) {
                System.out.println(“!IFF_UP…skipping getNetInterfaceStat”);
                 continue;
            }
            NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
            System.out.println(name + “接收的总包裹数:” + ifstat.getRxPackets()); //  接收的总包裹数

            System.out.println(name + “发送的总包裹数:” + ifstat.getTxPackets()); //  发送的总包裹数

            System.out.println(name + “接收到的总字节数:” + ifstat.getRxBytes()); //  接收到的总字节数

            System.out.println(name + “发送的总字节数:” + ifstat.getTxBytes()); //  发送的总字节数

            System.out.println(name + “接收到的错误包数:” + ifstat.getRxErrors()); //  接收到的错误包数

            System.out.println(name + “发送数据包时的错误数:” + ifstat.getTxErrors()); //  发送数据包时的错误数

            System.out.println(name + “接收时丢弃的包数:” + ifstat.getRxDropped()); //  接收时丢弃的包数

            System.out.println(name + “发送时丢弃的包数:” + ifstat.getTxDropped()); //  发送时丢弃的包数

        }
    }

     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() + “网关广播地址:” + cfg.getBroadcast()); //  网关广播地址

            System.out.println(cfg.getName() + “网卡MAC地址:” + cfg.getHwaddr()); //  网卡MAC地址

            System.out.println(cfg.getName() + “子网掩码:” + cfg.getNetmask()); //  子网掩码

            System.out.println(cfg.getName() + “网卡描述信息:” + cfg.getDescription()); //  网卡描述信息

            System.out.println(cfg.getName() + “网卡类型” + cfg.getType()); //

        }
    }
}




































































































































































































复制代码

 

运行结果:

 


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

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

(0)
上一篇 2026年3月17日 下午1:53
下一篇 2026年3月17日 下午1:53


相关推荐

  • Sufer白化实现

    Sufer白化实现swpu nbsp 物探 nbsp 杨连刚 nbsp 2018 4 13 nbsp 二维坐标系下 不规则网格 已知坐标 x y 及对应位置值 val 绘制等值线云图 能解决这个问题 特别感谢长安大学王琦同学热心帮助 步骤 1 根据起伏边界 按照逆时针建立边界白化文件 第一排第一列为数据点个数 第一排第二列为 0 1 区域内白化区域外白化 第二行开始 第一列为 x 坐标第二列为 y 坐标 设置完毕后 保存为 bln 格式白化文件 需要注

    2026年3月18日
    1
  • 学会使用getopt函数[通俗易懂]

    学会使用getopt函数[通俗易懂]简介getopt函数是命令行参数解析函数,在平时阅读源码的时候经常遇到,很有必要对其总结一下,做个记录!命令行参数各组成部分的名称先来了解下命令行参数各组成部分的名称。直接上图:非常清楚,命令行参数由Commandname,Option,Optionargument以及Operands组成。Commandname不用多说,就是程序的名称。操作对象Operands又…

    2022年6月9日
    50
  • cas6.2整合springboot入坑指南

    cas6.2整合springboot入坑指南

    2020年11月9日
    349
  • WebStorm常用快捷键(Mac版)

    WebStorm常用快捷键(Mac版)⌘——Command⌃——Control⌥——alt⇧——Shift⇪——CapsLockfn——功能键就是fn编辑Command+alt+T用(if..else,try..catch,for,etc.)包住Command+/注释/取消注释的行注释Command+alt+/注释/取消注释与块注释alt+↑向上选取代码块alt+↓向下选取代码块Command+alt+L格式化代码tab,shift+tab调整缩进Control+alt+I快

    2022年5月27日
    43
  • 个人对json的一些简单理解「建议收藏」

    个人对json的一些简单理解「建议收藏」在最近的学习中,查阅了很多资料,了解了一些关于json的基本知识,下面做一个简单的总结:json是什么没有.json结尾的这种文件,json(JavaScriptObjectNotation)是一种简单的数据交换格式,在此之前我也不知道这个东西其实没有想象的那么抽象,看看后面的例子会更清晰json中的数据结构json中只有两种数据基本结构,一种是MAP,或者叫对象,另一种是Ar…

    2022年6月9日
    43
  • Eclipse深度患者设置VSCode快捷键「建议收藏」

    Eclipse深度患者设置VSCode快捷键「建议收藏」VSCode设置Eclipse中常用的快捷键将eclipse中一些基本的快捷键输入右侧用户快捷键设置中://Placeyourkeybindingsinthisfiletooverwritethedefaults[{"key":"alt+/","command":"editor.action.triggerSuggest","when":…

    2022年5月27日
    78

发表回复

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

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