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 组件实现及扩展系统监控
316 0
|
3天前
|
SQL JavaScript 前端开发
vue中使用分页组件、将从数据库中查询出来的数据分页展示(前后端分离SpringBoot+Vue)
这篇文章详细介绍了如何在Vue.js中使用分页组件展示从数据库查询出来的数据,包括前端Vue页面的表格和分页组件代码,以及后端SpringBoot的控制层和SQL查询语句。
vue中使用分页组件、将从数据库中查询出来的数据分页展示(前后端分离SpringBoot+Vue)
|
2天前
|
前端开发 JavaScript Java
SpringBoot+Vue+token实现(表单+图片)上传、图片地址保存到数据库。上传图片保存位置自己定义、图片可以在前端回显(一))
这篇文章详细介绍了在SpringBoot+Vue项目中实现表单和图片上传的完整流程,包括前端上传、后端接口处理、数据库保存图片路径,以及前端图片回显的方法,同时探讨了图片资源映射、token验证、过滤器配置等相关问题。
|
2天前
|
前端开发 数据库
SpringBoot+Vue+token实现(表单+图片)上传、图片地址保存到数据库。上传图片保存位置到项目中的静态资源下、图片可以在前端回显(二))
这篇文章是关于如何在SpringBoot+Vue+token的环境下实现表单和图片上传的优化篇,主要改进是将图片保存位置从磁盘指定位置改为项目中的静态资源目录,使得图片资源可以跨环境访问,并在前端正确回显。
|
2天前
|
前端开发 数据库
SpringBoot+Vue实现商品不能重复加入购物车、购物车中展示商品的信息、删除商品重点提示等操作。如何点击图片实现图片放大
这篇文章介绍了如何在SpringBoot+Vue框架下实现购物车功能,包括防止商品重复加入、展示商品信息、删除商品时的提示,以及点击图片放大的前端实现。
SpringBoot+Vue实现商品不能重复加入购物车、购物车中展示商品的信息、删除商品重点提示等操作。如何点击图片实现图片放大
|
3天前
|
JSON JavaScript 前端开发
基于SpringBoot + Vue实现单个文件上传(带上Token和其它表单信息)的前后端完整过程
本文介绍了在SpringBoot + Vue项目中实现单个文件上传的同时携带Token和其它表单信息的前后端完整流程,包括后端SpringBoot的文件上传处理和前端Vue使用FormData进行表单数据和文件的上传。
10 0
基于SpringBoot + Vue实现单个文件上传(带上Token和其它表单信息)的前后端完整过程
|
3天前
|
JavaScript 前端开发 easyexcel
基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的前后端完整过程
本文展示了基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的完整过程,包括后端使用EasyExcel生成Excel文件流,前端通过Blob对象接收并触发下载的操作步骤和代码示例。
10 0
基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的前后端完整过程
|
3天前
|
数据库
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
这篇文章介绍了如何在基于SpringBoot+Vue+MybatisPlus的项目中使用elementUI的dialog组件进行用户信息的添加和删除操作,包括弹窗表单的设置、信息提交、数据库操作以及删除前的信息提示和确认。
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
|
3天前
|
JavaScript Java Spring
springboot+vue 实现校园二手商城(毕业设计一)
这篇文章介绍了一个使用Spring Boot和Vue实现的校园二手商城系统的毕业设计,包括用户和商家的功能需求,如登录注册、订单管理、商品评价、联系客服等,以及项目依赖项的安装过程。
springboot+vue 实现校园二手商城(毕业设计一)
|
3天前
|
JavaScript Java BI
Springboot+vue 实现汽车租赁系统(毕业设计二)(前后端项目分离)
这篇文章介绍了如何使用Springboot和Vue实现一个前后端分离的汽车租赁系统,包括系统的功能模块和管理员与业务员的使用界面。
Springboot+vue 实现汽车租赁系统(毕业设计二)(前后端项目分离)