SpringBoot系统监控,oshi版

简介: SpringBoot系统监控,oshi版

@[TOC]

前言

  • 今日访问mybatis-plus 官网偶然看到一个爱组搭广告,出于好奇点进去看了一下

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.构建maven

<dependency>
  <groupId>com.aizuda</groupId>
  <artifactId>aizuda-monitor</artifactId>
  <version>1.0.0</version>
</dependency>

2.代码示例

package cn.itcast.user.web;

import com.aizuda.monitor.DiskInfo;
import com.aizuda.monitor.OshiMonitor;
import com.alibaba.nacos.common.utils.CollectionUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import oshi.software.os.OSProcess;
import oshi.software.os.OperatingSystem;

import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @auther:Wangxl
 * @Emile:18335844494@163.com
 * @Time:2022/4/2 15:16
 */
@RestController
@RequestMapping("/v1/monitor")
public class MonitorController {

    // 注入监控模块 Oshi 调用类
    @Resource
    private OshiMonitor oshiMonitor;

    @GetMapping("/server")
    public Map<String, Object> monitor() {
        Map<String, Object> server = new HashMap<>(5);
        // 系统信息
        server.put("sysInfo", oshiMonitor.getSysInfo());
        // CPU 信息
        server.put("cupInfo", oshiMonitor.getCpuInfo());
        // 内存信息
        server.put("memoryInfo", oshiMonitor.getMemoryInfo());
        // Jvm 虚拟机信息
        server.put("jvmInfo", oshiMonitor.getJvmInfo());
        // 磁盘信息
        List<DiskInfo> diskInfos = oshiMonitor.getDiskInfos();
        server.put("diskInfos", diskInfos);
        if (CollectionUtils.isNotEmpty(diskInfos)) {
            long usableSpace = 0;
            long totalSpace = 0;
            for (DiskInfo diskInfo : diskInfos) {
                usableSpace += diskInfo.getUsableSpace();
                totalSpace += diskInfo.getTotalSpace();
            }
            double usedSize = (totalSpace - usableSpace);
            // 统计所有磁盘的使用率
            server.put("diskUsePercent", oshiMonitor.formatDouble(usedSize / totalSpace * 100));
        }

        // 系统前 10 个进程
        List<OSProcess> processList = oshiMonitor.getOperatingSystem().getProcesses(null,
                OperatingSystem.ProcessSorting.CPU_DESC, 10);
        List<Map<String, Object>> processMapList = new ArrayList<>();
        for (OSProcess process : processList) {
            Map<String, Object> processMap = new HashMap<>(5);
            processMap.put("name", process.getName());
            processMap.put("pid", process.getProcessID());
            processMap.put("cpu", oshiMonitor.formatDouble(process.getProcessCpuLoadCumulative()));
            processMapList.add(processMap);
        }
        server.put("processList", processMapList);
        return server;
    }

}

3.结果返回(前端展示需要自己开发,oshi只提供数据)

{
"cupInfo": {
"physicalProcessorCount": 4,
"logicalProcessorCount": 8,
"systemPercent": 0.09,
"userPercent": 0.08,
"waitPercent": 0.0,
"usePercent": 0.18
},
"memoryInfo": {
"total": "15.81GB",
"used": "11.79GB",
"free": "4.02GB",
"usePercent": 0.75
},
"processList": [
{
"name": "Idle",
"cpu": 7.41,
"pid": 0
},
{
"name": "javaw",
"cpu": 0.4,
"pid": 9540
},
{
"name": "idea64",
"cpu": 0.07,
"pid": 12840
},
{
"name": "msedge",
"cpu": 0.06,
"pid": 15956
},
{
"name": "java",
"cpu": 0.05,
"pid": 2400
},
{
"name": "java",
"cpu": 0.05,
"pid": 9760
},
{
"name": "msedge",
"cpu": 0.04,
"pid": 16768
},
{
"name": "msedge",
"cpu": 0.04,
"pid": 15444
},
{
"name": "msedge",
"cpu": 0.03,
"pid": 7860
},
{
"name": "QQPCTray",
"cpu": 0.02,
"pid": 9568
}
],
"sysInfo": {
"name": "DESKTOP-4BGLRMJ",
"ip": "172.23.39.68",
"osName": "Windows 10",
"osArch": "amd64",
"userDir": "F:\\2022Projects\\cloud-demo-dubbo"
},
"diskUsePercent": 47.1,
"diskInfos": [
{
"name": "本地固定磁盘 (C:)",
"volume": "\\\\?\\Volume{0ee2db33-fc0a-464f-aa79-f110edd1be4b}\\",
"label": "OS",
"logicalVolume": "",
"mount": "C:\\",
"description": "Fixed drive",
"options": "rw,reparse,sparse,trans,journaled,quota,casess,oids,casepn,efs,streams,unicode,acls,fcomp",
"type": "NTFS",
"size": "103.73GB",
"totalSpace": 111376592896,
"used": "89.17GB",
"usableSpace": 15626911744,
"avail": "14.55GB",
"usePercent": 85.97,
"uuid": "0ee2db33-fc0a-464f-aa79-f110edd1be4b"
},
{
"name": "本地固定磁盘 (D:)",
"volume": "\\\\?\\Volume{b6dd9496-40b0-416d-8fca-fb27692d3883}\\",
"label": "DATA",
"logicalVolume": "",
"mount": "D:\\",
"description": "Fixed drive",
"options": "rw,reparse,sparse,trans,journaled,quota,casess,oids,casepn,efs,streams,unicode,acls,fcomp",
"type": "NTFS",
"size": "531.39GB",
"totalSpace": 570572140544,
"used": "244.99GB",
"usableSpace": 307517067264,
"avail": "286.4GB",
"usePercent": 46.1,
"uuid": "b6dd9496-40b0-416d-8fca-fb27692d3883"
},
{
"name": "本地固定磁盘 (E:)",
"volume": "\\\\?\\Volume{3fdb949e-bba5-4052-bad9-275232a18e7e}\\",
"label": "新加卷",
"logicalVolume": "",
"mount": "E:\\",
"description": "Fixed drive",
"options": "rw,reparse,sparse,trans,journaled,quota,casess,oids,casepn,efs,streams,unicode,acls,fcomp",
"type": "NTFS",
"size": "200GB",
"totalSpace": 214747312128,
"used": "24.41GB",
"usableSpace": 188541489152,
"avail": "175.59GB",
"usePercent": 12.2,
"uuid": "3fdb949e-bba5-4052-bad9-275232a18e7e"
},
{
"name": "本地固定磁盘 (F:)",
"volume": "\\\\?\\Volume{72ed311d-d25b-4368-b5d3-e3f2e40d6aa8}\\",
"label": "新加卷",
"logicalVolume": "",
"mount": "F:\\",
"description": "Fixed drive",
"options": "rw,reparse,sparse,trans,journaled,quota,casess,oids,casepn,efs,streams,unicode,acls,fcomp",
"type": "NTFS",
"size": "200GB",
"totalSpace": 214747312128,
"used": "128.99GB",
"usableSpace": 76241727488,
"avail": "71.01GB",
"usePercent": 64.5,
"uuid": "72ed311d-d25b-4368-b5d3-e3f2e40d6aa8"
}
],
"jvmInfo": {
"jdkVersion": "1.8.0_131",
"jdkHome": "D:\\Java\\jdk1.8.0_131\\jre",
"jdkName": "Java HotSpot(TM) 64-Bit Server VM",
"jvmTotalMemory": "540MB",
"maxMemory": "3.51GB",
"freeMemory": "446.6MB",
"usedMemory": "93.4MB",
"usePercent": 0.17,
"startTime": 1648884476737,
"uptime": 310174
}
}
相关文章
|
监控 Java 关系型数据库
SpringBoot - 构建监控体系01_使用 Actuator 组件实现及扩展系统监控
SpringBoot - 构建监控体系01_使用 Actuator 组件实现及扩展系统监控
501 0
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。
|
3月前
|
搜索推荐 JavaScript Java
基于springboot的儿童家长教育能力提升学习系统
本系统聚焦儿童家长教育能力提升,针对家庭教育中理念混乱、时间不足、个性化服务缺失等问题,构建科学、系统、个性化的在线学习平台。融合Spring Boot、Vue等先进技术,整合优质教育资源,提供高效便捷的学习路径,助力家长掌握科学育儿方法,促进儿童全面健康发展,推动家庭和谐与社会进步。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的古树名木保护管理系统
本研究针对古树保护面临的严峻挑战,构建基于Java、Vue、MySQL与Spring Boot技术的信息化管理系统,实现古树资源的动态监测、数据管理与科学保护,推动生态、文化与经济可持续发展。
|
3月前
|
监控 安全 JavaScript
2025基于springboot的校车预定全流程管理系统
针对传统校车管理效率低、信息不透明等问题,本研究设计并实现了一套校车预定全流程管理系统。系统采用Spring Boot、Java、Vue和MySQL等技术,实现校车信息管理、在线预定、实时监控等功能,提升学校管理效率,保障学生出行安全,推动教育信息化发展。
|
3月前
|
人工智能 Java 关系型数据库
基于springboot的画品交流系统
本项目构建基于Java+Vue+SpringBoot+MySQL的画品交流系统,旨在解决传统艺术交易信息不透明、流通受限等问题,融合区块链与AI技术,实现画品展示、交易、鉴赏与社交一体化,推动艺术数字化转型与文化传播。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的高校运动会系统
本系统基于Spring Boot、Vue与MySQL,实现高校运动会报名、赛程安排及成绩管理的全流程信息化,提升组织效率,杜绝信息错漏与冒名顶替,推动体育赛事智能化发展。
|
3月前
|
JavaScript 安全 Java
基于springboot的大学生兼职系统
本课题针对大学生兼职信息不对称、权益难保障等问题,研究基于Spring Boot、Vue、MySQL等技术的兼职系统,旨在构建安全、高效、功能完善的平台,提升大学生就业竞争力与兼职质量。
|
3月前
|
JavaScript Java 关系型数据库
基于springboot的美食城服务管理系统
本系统基于Spring Boot、Java、Vue和MySQL技术,构建集消费者服务、商家管理与后台监管于一体的美食城综合管理平台,提升运营效率与用户体验。