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");
    }
相关推荐
mghio4 小时前
Dubbo 中的集群容错
java·微服务·dubbo
咖啡教室8 小时前
java日常开发笔记和开发问题记录
java
咖啡教室9 小时前
java练习项目记录笔记
java
鱼樱前端9 小时前
maven的基础安装和使用--mac/window版本
java·后端
RainbowSea10 小时前
6. RabbitMQ 死信队列的详细操作编写
java·消息队列·rabbitmq
RainbowSea10 小时前
5. RabbitMQ 消息队列中 Exchanges(交换机) 的详细说明
java·消息队列·rabbitmq
李少兄11 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
此木|西贝11 小时前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖12 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信