当前位置: 首页 > article >正文

SpringBoot+Redis获取电脑信息

获取电脑信息

测试

System.getProperties();

System: 是Java中的一个内置类,用于提供与系统相关的功能和信息。这个类中包含了一些静态方法和常量,可以让您方便地访问和操作系统级别的资源。

getProperties(): 是一个静态方法,它返回一个表示当前系统属性的Properties对象。这个方法可以用于获取系统相关的属性和信息,例如系统的操作系统、Java版本、路径分隔符等。、

package com.sin;

import com.sun.management.OperatingSystemMXBean;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import java.io.File;
import java.io.IOException;
import java.lang.management.ManagementFactory;
import java.nio.file.FileStore;
import java.nio.file.Files;
import java.util.Properties;

@SpringBootTest
class GetComputerMessages {

    Properties props = System.getProperties();
    OperatingSystemMXBean osBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();

    /**
     * 获取Java信息
     */
    @Test
    public void javaMessage() {
        System.out.println("Java的运行环境版本:" + props.getProperty("java.version"));
        System.out.println("Java的运行环境供应商:" + props.getProperty("java.vendor"));
        System.out.println("Java的运行环境供应商URL:" + props.getProperty("java.vendor.url"));
        System.out.println("Java的安装路径:" + props.getProperty("java.home"));
        System.out.println("Java的虚拟机规范名称:" + props.getProperty("java.vm.specification.name"));
        System.out.println("Java的虚拟机实现版本:" + props.getProperty("java.vm.version"));
        System.out.println("Java的虚拟机实现供应商:" + props.getProperty("java.vm.vendor"));
        System.out.println("Java的虚拟机实现名称:" + props.getProperty("java.vm.name"));
        System.out.println("Java的类格式版本号:" + props.getProperty("java.class.version"));
        System.out.println("Java的类路径:" + props.getProperty("java.class.path"));
        System.out.println("加载库时搜索的路径列表:" + props.getProperty("java.library.path"));
        System.out.println("默认的临时文件路径:" + props.getProperty("java.io.tmpdir"));
        System.out.println("一个或多个扩展目录的路径:" + props.getProperty("java.ext.dirs"));
        System.out.println("操作系统的名称:" + props.getProperty("os.name"));
        System.out.println("操作系统的构架:" + props.getProperty("os.arch"));
        System.out.println("操作系统的版本:" + props.getProperty("os.version"));
        System.out.println("分件分隔符:" + props.getProperty("file.separator"));// 在 unix 系统中是"/"
        System.out.println("路径分隔符:" + props.getProperty("path.separator"));// 在 unix 系统中是":"
        System.out.println("行分隔符:" + props.getProperty("line.separator"));// 在 unix 系统中是"/n"
        System.out.println("用户的账户名称:" + props.getProperty("user.name"));
        System.out.println("用户的主目录:" + props.getProperty("user.home"));
        System.out.println("用户的当前工作主目录:" + props.getProperty("user.dir"));
    }

    /**
     * 获取jvm信息
     */
    @Test
    public void jvmMessage() {
        // 获取java虚拟机信息
        Runtime runtime = Runtime.getRuntime();

        long totalMemoryBytes = runtime.totalMemory(); // JVM的总内存(字节)
        long freeMemoryBytes = runtime.freeMemory(); // JVM的空闲内存(字节)
        long maxMemoryBytes = runtime.maxMemory(); // JVM的最大可用内存(字节)

        long totalMemoryMB = totalMemoryBytes / (1024 * 1024); // 转换为兆字节
        long freeMemoryMB = freeMemoryBytes / (1024 * 1024); // 转换为兆字节
        long maxMemoryMB = maxMemoryBytes / (1024 * 1024); // 转换为兆字节

        System.out.println("JVM的总内存:" + totalMemoryMB + "MB");
        System.out.println("JVM的空闲内存:" + freeMemoryMB + "MB");
        System.out.println("JVM的最大可用内存:" + maxMemoryMB + "MB");
    }

    /**
     * 获取cpu信息
     */
    @Test
    public void cpuMessage() {
        String cpuArch = System.getProperty("os.arch"); // CPU架构
        int cpuCores = Runtime.getRuntime().availableProcessors(); // CPU核心数
        String cpuName = System.getenv("PROCESSOR_IDENTIFIER"); // CPU名称
        System.out.println("CPU架构:" + cpuArch);
        System.out.println("CPU名称:" + cpuName);
        System.out.println("CPU核心数:" + cpuCores);

        double systemLoadAverage = osBean.getSystemLoadAverage(); // 系统平均负载
        double processCpuLoad = osBean.getProcessCpuLoad(); // 当前进程的CPU负载
        double systemCpuLoad = osBean.getSystemCpuLoad(); // 系统的CPU负载
        System.out.println("系统平均负载:" + systemLoadAverage);
        System.out.println("当前进程的CPU负载:" + processCpuLoad);
        System.out.println("系统的cpu负载:" + systemCpuLoad);

        double userCpuLoad = osBean.getProcessCpuTime() / 1000000.0; // 用户态CPU时间
        double systemCpuTime = osBean.getSystemCpuLoad() * osBean.getAvailableProcessors(); // 系统态CPU时间
        double idleCpuTime = (1 - osBean.getSystemCpuLoad()) * osBean.getAvailableProcessors(); // 空闲CPU时间

        System.out.println("用户使用率:" + userCpuLoad);
        System.out.println("系统使用率:" + systemCpuTime);
        System.out.println("当前空闲率:" + idleCpuTime);
    }

    /**
     * 内存信息
     */
    @Test
    public void memoryMessage() {
        // 获取内存
        long totalPhysicalMemorySize = osBean.getTotalPhysicalMemorySize(); // 物理内存总量
        long freePhysicalMemorySize = osBean.getFreePhysicalMemorySize(); // 空闲物理内存量
        long totalSwapSpaceSize = osBean.getTotalSwapSpaceSize(); // 交换空间总量
        long freeSwapSpaceSize = osBean.getFreeSwapSpaceSize(); // 空闲交换空间量

        System.out.println("物理内存总量:" + totalPhysicalMemorySize / (1024 * 1024) + " MB");
        System.out.println("空闲物理内存量:" + freePhysicalMemorySize / (1024 * 1024) + " MB");
        System.out.println("交换空间总量:" + totalSwapSpaceSize / (1024 * 1024) + " MB");
        System.out.println("空闲交换空间量:" + freeSwapSpaceSize / (1024 * 1024) + " MB");

        long totalMemorySize = osBean.getTotalPhysicalMemorySize(); // 总内存大小
        long freeMemorySize = osBean.getFreePhysicalMemorySize(); // 空闲内存大小
        long usedMemorySize = totalMemorySize - freeMemorySize; // 已用内存大小
        double memoryUsage = (double) usedMemorySize / totalMemorySize * 100; // 内存使用率

        System.out.println("总内存:" + formatMemorySize(totalMemorySize));
        System.out.println("已用内存:" + formatMemorySize(usedMemorySize));
        System.out.println("剩余内存:" + formatMemorySize(freeMemorySize));
        System.out.println("内存使用率:" + String.format("%.2f", memoryUsage) + "%");
    }

    /**
     * 获取磁盘信息
     */
    @Test
    public void diskMessage() {
        File[] roots = File.listRoots();
        for (File root : roots) {
            String path = root.getAbsolutePath();
            long totalSpace = root.getTotalSpace(); // 总容量
            long usableSpace = root.getUsableSpace(); // 可用容量
            double usage = (double) (totalSpace - usableSpace) / totalSpace * 100; // 使用率

            System.out.println("磁盘路径:" + path);
            System.out.println("总容量:" + formatMemorySize(totalSpace));
            System.out.println("可用容量:" + formatMemorySize(usableSpace));
            System.out.println("使用率:" + String.format("%.2f", usage) + "%");

            try {
                FileStore store = Files.getFileStore(root.toPath());
                String fsType = store.type();
                String fsName = store.name();
                System.out.println("文件系统类型:" + fsType);
                System.out.println("文件系统名称:" + fsName);
            } catch (IOException e) {
                e.printStackTrace();
            }

            System.out.println();
        }
    }


    /**
     * 格式化容量大小
     *
     * @param bytes
     * @return
     */
    private static String formatMemorySize(long bytes) {
        double kiloBytes = bytes / 1024.0; // 将字节数转换为千字节
        double megaBytes = kiloBytes / 1024.0; // 将千字节转换为兆字节
        double gigaBytes = megaBytes / 1024.0; // 将兆字节转换为千兆字节

        if (gigaBytes >= 1) { // 如果容量大于等于1GB
            return String.format("%.2f GB", gigaBytes); // 格式化输出千兆字节容量,并带有两位小数的GB单位
        } else if (megaBytes >= 1) { // 如果容量大于等于1MB
            return String.format("%.2f MB", megaBytes); // 格式化输出兆字节容量,并带有两位小数的MB单位
        } else if (kiloBytes >= 1) { // 如果容量大于等于1KB
            return String.format("%.2f KB", kiloBytes); // 格式化输出千字节容量,并带有两位小数的KB单位
        } else { // 如果容量小于1KB
            return String.format("%d B", bytes); // 格式化输出字节数
        }
    }
}

java信息

在这里插入图片描述

内存信息

在这里插入图片描述

磁盘信息

在这里插入图片描述

jvm信息

在这里插入图片描述

CPU信息

在这里插入图片描述

整合Redis进行存储信息

package com.sin.controller;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.sin.utils.RedisUtil;
import com.sun.management.OperatingSystemMXBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.*;

import java.io.File;
import java.io.IOException;
import java.lang.management.ManagementFactory;
import java.nio.file.FileStore;
import java.nio.file.Files;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;

/**
 * @createTime 2023/11/30 11:52
 * @createAuthor SIN
 * @use
 */
@RestController
public class RedisTestController {

    @Autowired
    private RedisTemplate redisTemplate;

    @Autowired
    private RedisUtil redisUtil;

    Properties properties = System.getProperties();

    OperatingSystemMXBean osBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();


    /**
     * java信息
     * @return
     */
    @PostMapping("/setJavaMessage")
    public String setJavaMessage(){
        Map<String,Object>  javaPropertiesMap = new HashMap<String,Object>();
        javaPropertiesMap.put("Java版本:" , properties.getProperty("java.version"));
        javaPropertiesMap.put("Java安装日期:" , properties.getProperty("java.version.date"));
        javaPropertiesMap.put("Java运行环境提供商:" , properties.getProperty("java.vendor"));
        javaPropertiesMap.put("Java安装路径:" , properties.getProperty("java.home"));
        javaPropertiesMap.put("Java虚拟机规范名称:" , properties.getProperty("java.vm.specification.name"));
        javaPropertiesMap.put("Java虚拟机版本:" , properties.getProperty("java.vm.version"));
        javaPropertiesMap.put("Java虚拟机提供商" , properties.getProperty("java.vm.vendor"));
        javaPropertiesMap.put("Java虚拟机实现名称" , properties.getProperty("java.vm.name"));
        javaPropertiesMap.put("Java类的格式版本号" , properties.getProperty("java.class.version"));
        javaPropertiesMap.put("Java类路径" , properties.getProperty("java.class.path"));
        javaPropertiesMap.put("加载库时搜索的路径列表:" , properties.getProperty("java.library.path"));
        javaPropertiesMap.put("默认的临时文件路径:" , properties.getProperty("java.io.tmpdir"));
        javaPropertiesMap.put("操作系统的名称:" , properties.getProperty("os.name"));
        javaPropertiesMap.put("操作系统的架构" , properties.getProperty("os.arch"));
        javaPropertiesMap.put("操作系统的版本" , properties.getProperty("os.version"));
        javaPropertiesMap.put("文件分隔符:" , properties.getProperty("file.separator"));// unix文件分割符 "/"
        javaPropertiesMap.put("路径分隔符:" , properties.getProperty("path.separator"));// unix系统分隔符 ":"
        javaPropertiesMap.put("行分隔符" , properties.getProperty("line.separator"));    // unix系统 "/n"
        javaPropertiesMap.put("用户的账户名称:" , properties.getProperty("user.name"));
        javaPropertiesMap.put("用户的主目录:" , properties.getProperty("user.home"));
        javaPropertiesMap.put("用户当前工作主目录:" , properties.getProperty("user.dir"));
        /**
         * java_message : hash姓名
         * javaPropertiesMap : hash键值对
         * 60 : 该数据存活60秒
         */
        redisUtil.hmset("java_message",javaPropertiesMap,60);
        return "set success";
    }

    /**
     * jvm信息
     * @return
     */
    @PostMapping("/setJVMMessage")
    public String setJVMMMessage(){
        Map<String,Object>  jvmPropertiesMap = new HashMap<String,Object>();
        Runtime runtime = Runtime.getRuntime();

        long totalMemoryBytes = runtime.totalMemory(); // JVM的总内存(字节)
        long freeMemoryBytes = runtime.freeMemory(); // JVM的空闲内存(字节)
        long maxMemoryBytes = runtime.maxMemory(); // JVM的最大可用内存(字节)
        long totalMemoryMB = totalMemoryBytes / (1024 * 1024); // 转换为兆字节
        long freeMemoryMB = freeMemoryBytes / (1024 * 1024); // 转换为兆字节
        long maxMemoryMB = maxMemoryBytes / (1024 * 1024); // 转换为兆字节

        jvmPropertiesMap.put("JVM的总内存:", totalMemoryMB + "MB");
        jvmPropertiesMap.put("JVM的空闲内存:" , freeMemoryMB + "MB");
        jvmPropertiesMap.put("JVM的最大可用内存:" , maxMemoryMB + "MB");

        /**
         * java_message : hash姓名
         * javaPropertiesMap : hash键值对
         * 60 : 该数据存活60秒
         */
        redisUtil.hmset("jvm_message",jvmPropertiesMap,60);
        return "set success";
    }

    /**
     * cpu信息
     * @return
     */
    @PostMapping("/cpuMessage")
    public String cpuMessage(){
        Map<String,Object>  cpuPropertiesMap = new HashMap<String,Object>();

        String cpuArch = System.getProperty("os.arch"); // CPU架构
        int cpuCores = Runtime.getRuntime().availableProcessors(); // CPU核心数
        String cpuName = System.getenv("PROCESSOR_IDENTIFIER"); // CPU名称
        cpuPropertiesMap.put("CPU架构:" , cpuArch);
        cpuPropertiesMap.put("CPU名称:" , cpuName);
        cpuPropertiesMap.put("CPU核心数:" , cpuCores);

        double systemLoadAverage = osBean.getSystemLoadAverage(); // 系统平均负载
        double processCpuLoad = osBean.getProcessCpuLoad(); // 当前进程的CPU负载
        double systemCpuLoad = osBean.getSystemCpuLoad(); // 系统的CPU负载
        cpuPropertiesMap.put("系统平均负载:" ,systemLoadAverage);
        cpuPropertiesMap.put("当前进程的CPU负载:" , processCpuLoad);
        cpuPropertiesMap.put("系统的cpu负载:" , systemCpuLoad);

        double userCpuLoad = osBean.getProcessCpuTime() / 1000000.0; // 用户态CPU时间
        double systemCpuTime = osBean.getSystemCpuLoad() * osBean.getAvailableProcessors(); // 系统态CPU时间
        double idleCpuTime = (1 - osBean.getSystemCpuLoad()) * osBean.getAvailableProcessors(); // 空闲CPU时间

        cpuPropertiesMap.put("用户使用率:" , userCpuLoad);
        cpuPropertiesMap.put("系统使用率:" , systemCpuTime);
        cpuPropertiesMap.put("当前空闲率:" , idleCpuTime);

        redisUtil.hmset("cpu_message",cpuPropertiesMap);
        return "set success";
    }

    @PostMapping("/memoryMessage")
    public String memoryMessage(){

        Map<String,Object>  cpuPropertiesMap = new HashMap<String,Object>();
        // 获取内存
        long totalPhysicalMemorySize = osBean.getTotalPhysicalMemorySize(); // 物理内存总量
        long freePhysicalMemorySize = osBean.getFreePhysicalMemorySize(); // 空闲物理内存量
        long totalSwapSpaceSize = osBean.getTotalSwapSpaceSize(); // 交换空间总量
        long freeSwapSpaceSize = osBean.getFreeSwapSpaceSize(); // 空闲交换空间量

        cpuPropertiesMap.put("物理内存总量:" , totalPhysicalMemorySize / (1024 * 1024) + " MB");
        cpuPropertiesMap.put("空闲物理内存量:" ,freePhysicalMemorySize / (1024 * 1024) + " MB");
        cpuPropertiesMap.put("交换空间总量:" , totalSwapSpaceSize / (1024 * 1024) + " MB");
        cpuPropertiesMap.put("空闲交换空间量:" , freeSwapSpaceSize / (1024 * 1024) + " MB");

        long totalMemorySize = osBean.getTotalPhysicalMemorySize(); // 总内存大小
        long freeMemorySize = osBean.getFreePhysicalMemorySize(); // 空闲内存大小
        long usedMemorySize = totalMemorySize - freeMemorySize; // 已用内存大小
        double memoryUsage = (double) usedMemorySize / totalMemorySize * 100; // 内存使用率

        cpuPropertiesMap.put("总内存:" , formatMemorySize(totalMemorySize));
        cpuPropertiesMap.put("已用内存:" , formatMemorySize(usedMemorySize));
        cpuPropertiesMap.put("剩余内存:" , formatMemorySize(freeMemorySize));
        cpuPropertiesMap.put("内存使用率:" , String.format("%.2f", memoryUsage) + "%");
        redisUtil.hmset("memory_essage",cpuPropertiesMap);

        return "set success";
    }

    @PostMapping("/diskMessage")
    public String diskMessage(){

        Map<String,Object>  diskPropertiesMap = new HashMap<String,Object>();
        
        File[] roots = File.listRoots();
        for (File root : roots) {
            String path = root.getAbsolutePath();
            long totalSpace = root.getTotalSpace(); // 总容量
            long usableSpace = root.getUsableSpace(); // 可用容量
            double usage = (double) (totalSpace - usableSpace) / totalSpace * 100; // 使用率

            diskPropertiesMap.put("磁盘路径:" , path);
            diskPropertiesMap.put("总容量:" , formatMemorySize(totalSpace));
            diskPropertiesMap.put("可用容量:" , formatMemorySize(usableSpace));
            diskPropertiesMap.put("使用率:" , String.format("%.2f", usage) + "%");

            try {
                FileStore store = Files.getFileStore(root.toPath());
                String fsType = store.type();
                String fsName = store.name();
                diskPropertiesMap.put("文件系统类型:" , fsType);
                diskPropertiesMap.put("文件系统名称:" , fsName);
                redisUtil.hmset("disk_message"+fsName , diskPropertiesMap);
            } catch (IOException e) {
                e.printStackTrace();
            }

        }


        return "diskMessage set success";
    }

    /**
     * 格式化容量大小
     *
     * @param bytes
     * @return
     */
    private static String formatMemorySize(long bytes) {
        double kiloBytes = bytes / 1024.0; // 将字节数转换为千字节
        double megaBytes = kiloBytes / 1024.0; // 将千字节转换为兆字节
        double gigaBytes = megaBytes / 1024.0; // 将兆字节转换为千兆字节

        if (gigaBytes >= 1) { // 如果容量大于等于1GB
            return String.format("%.2f GB", gigaBytes); // 格式化输出千兆字节容量,并带有两位小数的GB单位
        } else if (megaBytes >= 1) { // 如果容量大于等于1MB
            return String.format("%.2f MB", megaBytes); // 格式化输出兆字节容量,并带有两位小数的MB单位
        } else if (kiloBytes >= 1) { // 如果容量大于等于1KB
            return String.format("%.2f KB", kiloBytes); // 格式化输出千字节容量,并带有两位小数的KB单位
        } else { // 如果容量小于1KB
            return String.format("%d B", bytes); // 格式化输出字节数
        }
    }



   

}

获取Redis数据

@GetMapping("/getMessage/{message}")
public Map<String, Object> getMessage(@PathVariable("message") String message) throws JsonProcessingException {
    // 获取 Hash 操作对象
    HashOperations<String, String, Object> hashOperations = redisTemplate.opsForHash();

    Map<String, Object> hashData = hashOperations.entries(message);

    return hashData;
}

vue渲染数据

<template>

    <div>
        <h1>磁盘信息</h1>
        <el-table :data="hashData" style="width: 100%;height: 100%">
            <el-table-column label="路径" prop="path"></el-table-column>
            <el-table-column label="使用率" prop="usage"></el-table-column>
            <el-table-column label="可用容量" prop="usableSpace"></el-table-column>
            <el-table-column label="总容量" prop="totalSpace"></el-table-column>
            <el-table-column label="文件系统名称" prop="fsName"></el-table-column>
            <el-table-column label="文件系统类型" prop="fsType"></el-table-column>
        </el-table>
    </div>
</template>

<script>
    import axios from "axios";

    export default {
        name: "DiskMessage",
        data() {
            return {
                hashData: [{
                    path:"",
                    usage:"",
                    usableSpace:"",
                    totalSpace:"",
                    fsName:"",
                    fsType:""
                }]
            };
        },
        mounted() {
            axios
                .get("http://localhost:8081/getDiskMessage", { withCredentials: true })
                .then(response => {
                    this.hashData = response.data;
                })
                .catch(error => {
                    console.log("数据获取有误:", error);
                });
        }
    };
</script>

<style scoped>

</style>

在这里插入图片描述


http://www.kler.cn/a/156563.html

相关文章:

  • 无人机应用场景:石油管道巡检技术详解
  • uni-app表格带分页,后端处理过每页显示多少条
  • 斯坦福泡茶机器人DexCap源码解析:涵盖收集数据、处理数据、模型训练三大阶段
  • 前端搭建低代码平台,微前端如何选型?
  • 大模型时代,呼叫中心的呼入机器人系统如何建设?
  • 如何进行产线高阶能耗数据的计算和可视化?
  • kicad源代码研究:参照Candence实现工程管理
  • 【恋上数据结构】哈夫曼树学习笔记
  • 全新仿某度文库网站源码/在线文库源码/文档分享平台网站源码/仿某度文库PHP源码
  • 在java中如何解决in unnamed module @0x602ff1d9得问题
  • vGPU_unlock实现消费级显卡虚拟化
  • 分享76个节日PPT,总有一款适合您
  • n皇后问题的最优解及优化
  • 国内的几款强大的AI智能—AI语言模型
  • ES6 generator Symbol yield
  • SpringBoot application.yml配置文件写法
  • homeassistant 随笔
  • java开发之个微机器人的实现
  • 面试题:MySQL为什么选择B+树作为索引结构
  • 135. 分发糖果
  • Linux结束程序运行的命令
  • GPIO的使用--存储系统与位带操作理解
  • 免费AI洗稿软件【2023最新】
  • 【JavaEE】多线程 (2) --线程安全
  • Elasticsearch 相似度评分模型介绍
  • JVM 运行时内存篇