springboot 动态加载sigar

说明

有些系统服务需要获取系统的性能参数,比如内存,CPU,网卡、存储等信息,sigar是一个不错的选择,不过麻烦的是使用该jar文件需要加载库文件,但是遍查全网,没有一篇可以动态按照操作系统加载类库文件的方式。因此自己实现了一个:

准备工作

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

备用下载地址:点击下载

下载 hyperic-sigar-1.6.4.zip 文件,下载地址:
解压 \hyperic-sigar-1.6.4\sigar-bin\lib 放入 src/main/resources/sigar.so下


image.png

引入maven依赖:

        <dependency>
            <groupId>org.fusesource</groupId>
            <artifactId>sigar</artifactId>
            <version>1.6.4</version>
        </dependency>

采用bean的方式动态加载,适配各种操作系统。

@Slf4j
@Configuration
public class SigarConfig {

    //静态代码块
    static {
        try {
            initSigar();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    //初始化sigar的配置文件
    public static void initSigar() throws IOException {
        SigarLoader loader = new SigarLoader(Sigar.class);
        String lib = null;

        try {
            lib = loader.getLibraryName();
            log.info("init sigar so文件====================="+lib);
        } catch (ArchNotSupportedException var7) {
            log.error("initSigar() error:{}",var7.getMessage());
        }
        ResourceLoader resourceLoader = new DefaultResourceLoader();
        Resource resource = resourceLoader.getResource("classpath:/sigar.so/" + lib);
        if (resource.exists()) {
            InputStream is = resource.getInputStream();
            File tempDir = new File("/var/log");
            if (!tempDir.exists()){
                tempDir.mkdirs();
            }
            BufferedOutputStream os = new BufferedOutputStream(new FileOutputStream(new File(tempDir, lib), false));
            int lentgh = 0;
            while ((lentgh = is.read()) != -1){
                os.write(lentgh);
            }

            is.close();
            os.close();
            System.setProperty("org.hyperic.sigar.path", tempDir.getCanonicalPath());
            // log.info("======================org.hyperic.sigar.path:"+System.getProperty("org.hyperic.sigar.path"));
        }

    }
}

sigar 使用例子

public static void main(String[] args) {
        try {
            log.info("-----------------开始-----------------");
            log.info("-----------------cpu信息-----------------");
            // cpu信息
            cpu();
            log.info("-----------------内存信息-----------------");

            // 内存信息
            memory();
            log.info("-----------------操作系统信息-----------------");

            // 操作系统信息
            os();
            log.info("-----------------用户信息-----------------");

            // 用户信息
            who();
            log.info("-----------------文件系统信息-----------------");

            // 文件系统信息
            file();
            log.info("-----------------网络信息-----------------");

            // 网络信息
            net();
            log.info("-----------------以太网信息-----------------");
            // 以太网信息
            ethernet();
            log.info("-----------------结束-----------------");

        } catch (Exception e1) {
            e1.printStackTrace();
        }
    }


private static void memory() throws SigarException {
        Sigar sigar = new Sigar();
        Mem mem = sigar.getMem();
        // 内存总量
        log.info("内存总量:    " + mem.getTotal() / 1024L + "K av");
        // 当前内存使用量
        log.info("当前内存使用量:    " + mem.getUsed() / 1024L + "K used");
        // 当前内存剩余量
        log.info("当前内存剩余量:    " + mem.getFree() / 1024L + "K free");
        Swap swap = sigar.getSwap();
        // 交换区总量
        log.info("交换区总量:    " + swap.getTotal() / 1024L + "K av");
        // 当前交换区使用量
        log.info("当前交换区使用量:    " + swap.getUsed() / 1024L + "K used");
        // 当前交换区剩余量
        log.info("当前交换区剩余量:    " + 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];
            log.info("第" + (i + 1) + "块CPU信息");
            log.info("CPU的总量MHz:    " + info.getMhz());// CPU的总量MHz
            log.info("CPU生产商:    " + info.getVendor());// 获得CPU的卖主,如:Intel
            log.info("CPU类别:    " + info.getModel());// 获得CPU的类别,如:Celeron
            log.info("CPU缓存数量:    " + info.getCacheSize());// 缓冲存储器数量
            printCpuPerc(cpuList[i]);
        }
    }

    private static void printCpuPerc(CpuPerc cpu) {
        log.info("CPU用户使用率:    " + CpuPerc.format(cpu.getUser()));// 用户使用率
        log.info("CPU系统使用率:    " + CpuPerc.format(cpu.getSys()));// 系统使用率
        log.info("CPU当前等待率:    " + CpuPerc.format(cpu.getWait()));// 当前等待率
        log.info("CPU当前错误率:    " + CpuPerc.format(cpu.getNice()));//
        log.info("CPU当前空闲率:    " + CpuPerc.format(cpu.getIdle()));// 当前空闲率
        log.info("CPU总的使用率:    " + CpuPerc.format(cpu.getCombined()));// 总的使用率
    }

    private static void os() {
        OperatingSystem OS = OperatingSystem.getInstance();
        // 操作系统内核类型如: 386、486、586等x86
        log.info("操作系统:    " + OS.getArch());
        log.info("操作系统CpuEndian():    " + OS.getCpuEndian());//
        log.info("操作系统DataModel():    " + OS.getDataModel());//
        // 系统描述
        log.info("操作系统的描述:    " + OS.getDescription());
        // 操作系统类型
        // log.info("OS.getName(): " + OS.getName());
        // log.info("OS.getPatchLevel(): " + OS.getPatchLevel());//
        // 操作系统的卖主
        log.info("操作系统的卖主:    " + OS.getVendor());
        // 卖主名称
        log.info("操作系统的卖主名:    " + OS.getVendorCodeName());
        // 操作系统名称
        log.info("操作系统名称:    " + OS.getVendorName());
        // 操作系统卖主类型
        log.info("操作系统卖主类型:    " + OS.getVendorVersion());
        // 操作系统的版本号
        log.info("操作系统的版本号:    " + 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++) {
                // log.info("当前系统进程表中的用户名" + String.valueOf(i));
                Who _who = who[i];
                log.info("用户控制台:    " + _who.getDevice());
                log.info("用户host:    " + _who.getHost());
                // log.info("getTime(): " + _who.getTime());
                // 当前系统进程表中的用户名
                log.info("当前系统进程表中的用户名:    " + _who.getUser());
            }
        }
    }

    private static void file() throws Exception {
        Sigar sigar = new Sigar();
        FileSystem fslist[] = sigar.getFileSystemList();
        for (int i = 0; i < fslist.length; i++) {
            log.info("分区的盘符名称" + i);
            FileSystem fs = fslist[i];
            // 分区的盘符名称
            log.info("盘符名称:    " + fs.getDevName());
            // 分区的盘符名称
            log.info("盘符路径:    " + fs.getDirName());
            log.info("盘符标志:    " + fs.getFlags());//
            // 文件系统类型,比如 FAT32、NTFS
            log.info("盘符类型:    " + fs.getSysTypeName());
            // 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
            log.info("盘符类型名:    " + fs.getTypeName());
            // 文件系统类型
            log.info("盘符文件系统类型:    " + 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 : 本地硬盘
                // 文件系统总大小
                log.info(fs.getDevName() + "总大小:    " + usage.getTotal() + "KB");
                // 文件系统剩余大小
                log.info(fs.getDevName() + "剩余大小:    " + usage.getFree() + "KB");
                // 文件系统可用大小
                log.info(fs.getDevName() + "可用大小:    " + usage.getAvail() + "KB");
                // 文件系统已经使用量
                log.info(fs.getDevName() + "已经使用量:    " + usage.getUsed() + "KB");
                double usePercent = usage.getUsePercent() * 100D;
                // 文件系统资源的利用率
                log.info(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;
            }
            log.info(fs.getDevName() + "读出:    " + usage.getDiskReads());
            log.info(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);
            log.info("网络设备名:    " + name);// 网络设备名
            log.info("IP地址:    " + ifconfig.getAddress());// IP地址
            log.info("子网掩码:    " + ifconfig.getNetmask());// 子网掩码
            if ((ifconfig.getFlags() & 1L) <= 0L) {
                log.info("!IFF_UP...skipping getNetInterfaceStat");
                continue;
            }
            NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
            log.info(name + "接收的总包裹数:" + ifstat.getRxPackets());// 接收的总包裹数
            log.info(name + "发送的总包裹数:" + ifstat.getTxPackets());// 发送的总包裹数
            log.info(name + "接收到的总字节数:" + ifstat.getRxBytes());// 接收到的总字节数
            log.info(name + "发送的总字节数:" + ifstat.getTxBytes());// 发送的总字节数
            log.info(name + "接收到的错误包数:" + ifstat.getRxErrors());// 接收到的错误包数
            log.info(name + "发送数据包时的错误数:" + ifstat.getTxErrors());// 发送数据包时的错误数
            log.info(name + "接收时丢弃的包数:" + ifstat.getRxDropped());// 接收时丢弃的包数
            log.info(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;
            }
            log.info(cfg.getName() + "IP地址:" + cfg.getAddress());// IP地址
            log.info(cfg.getName() + "网关广播地址:" + cfg.getBroadcast());// 网关广播地址
            log.info(cfg.getName() + "网卡MAC地址:" + cfg.getHwaddr());// 网卡MAC地址
            log.info(cfg.getName() + "子网掩码:" + cfg.getNetmask());// 子网掩码
            log.info(cfg.getName() + "网卡描述信息:" + cfg.getDescription());// 网卡描述信息
            log.info(cfg.getName() + "网卡类型" + cfg.getType());//
        }
    }

更多,请关注:
springboot 技术实践总结

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,295评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,928评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,682评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,209评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,237评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,965评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,586评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,487评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,016评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,136评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,271评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,948评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,619评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,139评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,252评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,598评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,267评论 2 358

推荐阅读更多精彩内容