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