java读取系统cpu,内存,硬盘信息

window的cmd,该命令会实时显示 CPU 使用率

bash 复制代码
typeperf "\Processor(_Total)\% Processor Time"

pom.xml依赖

xml 复制代码
        <dependency>
            <groupId>com.github.oshi</groupId>
            <artifactId>oshi-core</artifactId>
            <version>6.2.2</version>
        </dependency>

java代码实现

java 复制代码
    public static void main(String[] args) {
    
        SpringApplication.run(Iec104Application.class, args);
        
        SystemInfo systemInfo = new SystemInfo();
        
        HardwareAbstractionLayer hardware = systemInfo.getHardware();
        
        System.out.println(hardware.getComputerSystem());
        
        CentralProcessor processor = hardware.getProcessor();
        
        GlobalMemory memory = hardware.getMemory();
        
        FileSystem fileSystem = systemInfo.getOperatingSystem().getFileSystem();

        long[] prevTicks = processor.getSystemCpuLoadTicks();
        // 计算CPU负载百分比
        //一定要睡眠一下,不然cpu获取是平均的,不然可能是0
        Util.sleep(1000);
        double load = processor.getSystemCpuLoadBetweenTicks(prevTicks) * 100;
        System.out.println("CPU Load: " + String.format("%.1f", load) + "%");

        // 创建 DecimalFormat 对象,保留 1 位小数
        DecimalFormat df = new DecimalFormat("#.0");

        // 内存使用情况
        long totalMemory = memory.getTotal(); // 获取总内存
        double totalMemoryInGB = totalMemory / (1024.0 * 1024.0 * 1024.0); // 转换为 GB
        System.out.println("system.memory.total: " + df.format(totalMemoryInGB) + " GB");

        long usedMemory = totalMemory - memory.getAvailable(); // 已用内存
        double usedMemoryInGB = usedMemory / (1024.0 * 1024.0 * 1024.0); // 转换为 GB
        System.out.println("system.memory.used: " + df.format(usedMemoryInGB) + " GB");

        // 硬盘使用情况(总空间和已用空间)
        long totalDiskSpace = fileSystem.getFileStores().stream()
                .mapToLong(fs -> fs.getTotalSpace())
                .sum(); // 获取硬盘总空间
        double totalDiskSpaceInGB = totalDiskSpace / (1024.0 * 1024.0 * 1024.0); // 转换为 GB
        System.out.println("system.disk.total: " + df.format(totalDiskSpaceInGB) + " GB");
		
		// 获取已用硬盘空间,可以读取每一个盘符
        long usedDiskSpace = fileSystem.getFileStores().stream()
                .mapToLong(fs -> fs.getUsableSpace())
                .sum(); 
        double usedDiskSpaceInGB = usedDiskSpace / (1024.0 * 1024.0 * 1024.0); // 转换为 GB
        System.out.println("system.disk.used: " + df.format(usedDiskSpaceInGB) + " GB");
    }
相关推荐
皮皮林5516 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
卡尔特斯10 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源10 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole10 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫11 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide11 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户37215742613511 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源11 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群12 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心12 小时前
从零开始学Flink:数据源
java·大数据·后端·flink