package com.dy.common.util; import lombok.Data; import oshi.hardware.CentralProcessor; import oshi.util.Util; /** * @Author: liurunyu * @Date: 2024/8/2 11:17 * @Description */ public class SysCpuUtil { private static final int OSHI_WAIT_SECOND = 1000; /** * 得到CPU信息 */ public static CpuInfoVo info(CentralProcessor processor){ /** * 获取系统范围内的CPU负载计数器。返回一个包含八个元素的数组,表示在用户(0)、尼斯(1)、系统(2)、空闲(3)、 * IOwait(4)、硬件中断(IRQ)(5)、软件中断/DPC(SoftIRQ))(6)或窃取(7)状态下花费的毫秒数。使用 * {@link-shi.hardware.TickType#getIndex()}检索相应的索引。通过测量一个时间间 * 隔内滴答声之间的差异,可以计算出该时间间隔内的CPU负载。 * 在某些逻辑处理器数量可变的操作系统上,此阵列的大小可能会发生变化,并且可能与其他每处理器方法不一致。 * 请注意,虽然滴答计数器以毫秒为单位,但它们可能会随着(依赖于平台的)时钟滴答声以更大的增量前进。例如,默认 * 情况下,Windows时钟节拍为1/64秒(约15或16毫秒),Linux时钟节拍取决于分布和配置,但通常为1/100秒(10 * 毫秒)。 * Windows上没有Nice和IOWait信息,macOS上没有IOWait和IRQ信息,因此这些标记将始终为零。 * 要使用此方法计算总空闲时间,请同时包括Idle和IOWait标记。同样,应将IRQ、SoftIRQ和Steal标记添加到系统值 * 中以获得总和。系统计时还包括执行其他虚拟主机(窃取)的时间。 * * * @return一个由8个长值组成的数组,表示在User、Nice、System、Idle、IOwait、IRQ、SoftIRQ和Steal状态下花费的时间。 */ long[] prevTicks = processor.getSystemCpuLoadTicks(); Util.sleep(OSHI_WAIT_SECOND); long[] ticks = processor.getSystemCpuLoadTicks(); long nice = ticks[1] - prevTicks[1]; long irq = ticks[5] - prevTicks[5]; long softIrq = ticks[6] - prevTicks[6]; long steal = ticks[7] - prevTicks[7]; long cSys = ticks[2] - prevTicks[2]; long user = ticks[0] - prevTicks[0]; long ioWait = ticks[4] - prevTicks[4]; long idle = ticks[3] - prevTicks[3]; /* long nice = ticks[TickType.NICE.getIndex()] - prevTicks[TickType.NICE.getIndex()]; long irq = ticks[TickType.IRQ.getIndex()] - prevTicks[TickType.IRQ.getIndex()]; long softIrq = ticks[TickType.SOFTIRQ.getIndex()] - prevTicks[TickType.SOFTIRQ.getIndex()]; long steal = ticks[TickType.STEAL.getIndex()] - prevTicks[TickType.STEAL.getIndex()]; long cSys = ticks[TickType.SYSTEM.getIndex()] - prevTicks[TickType.SYSTEM.getIndex()]; long user = ticks[TickType.USER.getIndex()] - prevTicks[TickType.USER.getIndex()]; long ioWait = ticks[TickType.IOWAIT.getIndex()] - prevTicks[TickType.IOWAIT.getIndex()]; long idle = ticks[TickType.IDLE.getIndex()] - prevTicks[TickType.IDLE.getIndex()]; */ long totalCpu = user + nice + cSys + idle + ioWait + irq + softIrq + steal; CpuInfoVo vo = new CpuInfoVo() ; vo.cores = processor.getLogicalProcessorCount() ; vo.totalRate = totalCpu ; vo.sysRate = cSys ; vo.userRate = user ; vo.waitRate = ioWait ; vo.freeRate = idle ; return vo ; } @Data public static class CpuInfoVo{ /** * 核心数 */ public int cores; /** * CPU总的使用率 */ public double totalRate; /** * CPU系统使用率 */ public double sysRate; /** * CPU用户使用率 */ public double userRate; /** * CPU当前等待率 */ public double waitRate; /** * CPU当前空闲率 */ public double freeRate; public String toString(){ StringBuilder sb = new StringBuilder() ; sb.append(" CPU信息:\n"); sb.append(" 核心数:" + cores + "\n"); sb.append(" CPU总的使用率:" + totalRate + "\n"); sb.append(" CPU系统使用率:" + sysRate + "\n"); sb.append(" CPU用户使用率:" + userRate + "\n"); sb.append(" CPU当前等待率:" + waitRate + "\n"); sb.append(" CPU当前空闲率:" + freeRate + "\n"); return sb.toString() ; } } }