| New file | 
 |  |  | 
 |  |  | 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() ; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |     } | 
 |  |  | } |