关于后端:使用-OSHI-给你的-IDEA-status-bar-加上网速-CPU-统计

70次阅读

共计 2726 个字符,预计需要花费 7 分钟才能阅读完成。

关上 IDEA 感觉总是少了点什么,看着右下角空空的,总感觉短少一些什么。

关上一个新我的项目,看着他 download 依赖,我终于想起来短少什么了!短少网速!

所以说,须要在 status bar 上加上实时网速。

Mac 菜单栏加统计我晓得,有个 App 叫 stats

我只须要对照他做一个 Basic version for stats

根底版本,只须要网速统计就行了,当然如果能够加上 CPU、内存统计更好!

如何统计机器信息?

如果要监控一台机器的各项指标,须要怎么操作?那如果应用 Java 来监控各项指标,又该如何操作呢?

果决开始使用互联网搜索引擎查找材料。最终找到 oshi

OSHI 是一个收费的基于 JNA(本机)的 Java 操作系统和硬件信息库。不须要装置任何额定的本地库,旨在提供跨平台实现来检索系统信息,例如操作系统版本、过程、内存和 CPU 使用率、磁盘和分区、设施、传感器等。

更多的信息在 github 都有,包含应用形式在 oshi-demo module 下都有,也能够查 issue,外面有很多大家遇到的应用问题以及解决形式。

如何将信息放在 IDEA Status Bar

这个在 IDEA 外面反对扩大,应用 statusBarWidgetFactory 即可。

剩下的就是欢快的编程阶段了。

网速统计

上面这个是谬误的:

public class NetworkStatusBarWidget {private static SystemInfo systemInfo = new SystemInfo();
    private static HardwareAbstractionLayer hardware = systemInfo.getHardware();

    private String networkUsage() {List<NetworkIF> networkIFList = hardware.getNetworkIFs();
    NetworkIF net = networkIFList.get(networkIFList.size() - 1);

    // 谬误
    net.getSpeed();}
}

本认为 net.getSpeed(); 能够获取到网速,并且正文上也是这么写的。

然而实际上并不是这样,鉴于此只能去 issue 搜寻一番。

找到这两个 issue,基本上就确定答案了。

看圈进去的中央,这里就是说 net.getSpeed(); 并不是获取网速。

而理论获取网速须要计算。具体怎么计算,在另一个 issue 外面也有。

所以理论的代码应该是这样子的。

public class NetworkStatusBarWidget {private static SystemInfo systemInfo = new SystemInfo();
    private static HardwareAbstractionLayer hardware = systemInfo.getHardware();

    private String networkUsage() {List<NetworkIF> networkIFList = hardware.getNetworkIFs();
    NetworkIF net = networkIFList.get(networkIFList.size() - 1);
    long download1 = net.getBytesRecv();
    long upload1 = net.getBytesSent();
    long timestamp1 = net.getTimeStamp();
    Util.sleep(3000);
    net.updateAttributes();
    long download2 = net.getBytesRecv();
    long upload2 = net.getBytesSent();
    long timestamp2 = net.getTimeStamp();

    BigDecimal downloadDiff = new BigDecimal(download2 - download1);
    BigDecimal uploadDiff = new BigDecimal(upload2 - upload1);
    BigDecimal timestampDiff = new BigDecimal(timestamp2 - timestamp1);

    BigDecimal downloadPerSecond = downloadDiff.multiply(BigDecimal.valueOf(1000)).divide(timestampDiff, 2, RoundingMode.HALF_UP);
    BigDecimal uploadPerSecond = uploadDiff.multiply(BigDecimal.valueOf(1000)).divide(timestampDiff, 2, RoundingMode.HALF_UP);

    BigDecimal downKb = downloadPerSecond.divide(BigDecimal.valueOf(1024), 0, RoundingMode.HALF_UP);
    BigDecimal downMb = downKb.divide(BigDecimal.valueOf(1024), 1, RoundingMode.HALF_UP);

    BigDecimal uploadKb = uploadPerSecond.divide(BigDecimal.valueOf(1024), 0, RoundingMode.HALF_UP);
    BigDecimal uploadMb = uploadKb.divide(BigDecimal.valueOf(1024), 1, RoundingMode.HALF_UP);

    String text = "↑";
    if (uploadMb.compareTo(BigDecimal.ONE) > 0) {text = text + uploadMb + "MB/s";} else {text = text + uploadKb + "KB/s";}
    text = text + "↓";
    if (downMb.compareTo(BigDecimal.ONE) > 0) {text = text + downMb + "MB/s";} else {text = text + downKb + "KB/s";}

    return text;

    }
}

代码有点长,外围就是在两个时间段别离获取过后接管 / 发送的字节,而后计算得出。

除了网速监控之外,也能够减少其余监控,毕竟这是 OSHI 提供的能力,只须要略微批改就能够。

具体实现,能够看 源码。

总结

留神:这个插件并不能在 IDEA 中应用,没有做优化,会十分卡顿。并且可能会存在 bug,仅仅是用来参考。

如果有自研监控的需要,也能够钻研一下 OSHI。

最初,看下成果:

本文由 mdnice 多平台公布

正文完
 0