要监控spring数据 配置文件需要开启对应包扫描
spring.datasource.druid.aop-patterns= org.jeecg.modules.monitor.service.*
package org.jeecg.monitor.xxljob;
import com.alibaba.druid.stat.DruidStatManagerFacade;
import com.alibaba.druid.support.http.stat.WebAppStatManager;
import com.alibaba.druid.support.spring.stat.SpringStatManager;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.sun.management.OperatingSystemMXBean;
import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.handler.annotation.XxlJob;
import feign.FeignException;
import lombok.extern.slf4j.Slf4j;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.config.mqtoken.UserTokenContext;
import org.jeecg.common.constant.CommonConstant;
import org.jeecg.common.system.util.JwtUtil;
import org.jeecg.common.util.RedisUtil;
import org.jeecg.common.util.SpringContextUtils;
import org.jeecg.modules.monitor.entity.SysMonitor;
import org.jeecg.modules.monitor.service.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cache.annotation.CacheConfig;
import org.springframework.http.HttpMethod;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;
import org.springframework.web.client.RestTemplate;
import javax.annotation.Resource;
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.lang.management.ManagementFactory;
import java.lang.management.ThreadMXBean;
import java.math.BigDecimal;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.text.DecimalFormat;
import java.util.*;
import java.util.stream.Collectors;
/**
* @author 7788
* 系统服务状态监控定时任务
*/
@Component
@Slf4j
public class SystemMonitorHandler {
@Autowired
private RedisUtil redisTemplate;
@Autowired
private SysMonitorService sysMonitorService;
/**
* Druid druidStatManager# 该类可以获取所有数据源的监控数据。
*/
private final DruidStatManagerFacade druidStatManager = DruidStatManagerFacade.getInstance();
/**
* webAppStatManager 该类可以获取所有WEB应用的监控数据。
*/
private final WebAppStatManager webAppStatManager = WebAppStatManager.getInstance();
/**
* springStatManager 该类可以获取所有spring应用的监控数据。
*/
private final SpringStatManager springStatManager = SpringStatManager.getInstance();
@XxlJob(value = "systemIndexMonitor")
public ReturnT<String> systemIndexMonitor(String params) throws IOException {
//1.设置线程会话Token
String token = getTemporaryToken();
UserTokenContext.setToken(token);
String username = JwtUtil.getUsername(token);
//2.将数据信息封装到SysMonitor对象并插入数据库
List<SysMonitor> sysMonitors = new ArrayList<>();
Date date = new Date();
//3.获取系统服务器
//内存使用率
OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
long totalPhysicalMemorySize = osmxb.getTotalPhysicalMemorySize();
long usedMemory = osmxb.getTotalPhysicalMemorySize() - osmxb.getFreePhysicalMemorySize();
String memoryUsedRate = new DecimalFormat("#.##").format((double) usedMemory / (double) totalPhysicalMemorySize);
//cpu使用率
String systemCpuLoad = new DecimalFormat("#.##").format(osmxb.getSystemCpuLoad());
log.debug("memoryUsedRate:" + memoryUsedRate);
log.debug("cpuUsageSize:" + systemCpuLoad);
sysMonitors.add(new SysMonitor(username, "os", SysMonitorService.CPU_USAGE, systemCpuLoad, date));
sysMonitors.add(new SysMonitor(username, "os", SysMonitorService.MEMORY_USED, memoryUsedRate, date));
sysMonitors.add(new SysMonitor(username, "os", SysMonitorService.MEMORY_TOTAL, transformation(totalPhysicalMemorySize), date));
//4.系统服务器磁盘信息
String osName = System.getProperty("os.name");
if (osName.startsWith("Windows")) {
DecimalFormat df = new DecimalFormat("0.00");
File[] roots = File.listRoots();
for (File file : roots) {
long totalSpace = file.getTotalSpace();
long freeSpace = file.getFreeSpace();
long usedSpace = totalSpace - freeSpace;
//转化占用磁盘大小
float totalSpaceG = Float.parseFloat(df.format((float) totalSpace / 1024 / 1024 / 1024));
float freeSpaceG = Float.parseFloat(df.format((float) freeSpace / 1024 / 1024 / 1024));
float usedSpaceG = Float.parseFloat(df.format((float) usedSpace / 1024 / 1024 / 1024));
log.debug(file + " 容量 : " + totalSpaceG + "G, 可用 : " + freeSpaceG + "G, 已用 : " + usedSpaceG + "G");
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(file.getAbsolutePath()), "windowsTotalSpaceG", Float.toString(totalSpaceG), date));
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(file.getAbsolutePath()), "windowsFreeSpaceG", Float.toString(freeSpaceG), date));
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(file.getAbsolutePath()), "windowsUsedSpaceG", Float.toString(usedSpaceG), date));
}
} else {
try {
Runtime rt = Runtime.getRuntime();
Process p = rt.exec("df -hl");
try (BufferedReader in = new BufferedReader(new InputStreamReader(p.getInputStream()))) {
String str;
int line = 0;
while ((str = in.readLine()) != null) {
line++;
if (line == 1) {
continue;
}
str = str.replaceAll("\\s+", " ");
String[] strArray = str.split(" ");
log.debug("文件系统 " + strArray[0] + ",容量 " + strArray[1] + ",已用 " + strArray[2] + ",可用 " + strArray[3] + ",占比 " + strArray[4] + ",挂载目录 " + strArray[5]);
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(strArray[5]), "linuxTotalSpaceG", strArray[1], date));
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(strArray[5]), "linuxfreeSpaceG", strArray[2], date));
sysMonitors.add(new SysMonitor(username, SysMonitorService.DISK_PREFIX.concat(strArray[5]), "linuxUsedSpaceG", strArray[3], date));
}
} catch (Exception e) {
e.printStackTrace();
}
} catch (Exception e) {
e.printStackTrace();
}
}
//5.获取各个子系统应用指标
//运行监控服务指标
List<Map<String, Object>> webAppStatDataMonitor = webAppStatManager.getWebAppStatData();
List<Map<String, Object>> uriStatDataMonitor = webAppStatManager.getURIStatData();
List<Map<String, Object>> dataSourceStatDataListMonitor = druidStatManager.getDataSourceStatDataList();
List<Map<String, Object>> methodStatDataMonitor = springStatManager.getMethodStatData();
Set<Object> springStatSet = springStatManager.getSpringStatSet();
//处理数据
getData("jeecg-monitor", methodStatDataMonitor, sysMonitors, webAppStatDataMonitor, uriStatDataMonitor, dataSourceStatDataListMonitor, username, date);
//处理完数据 清空所有
druidStatManager.resetAll();
//其他系统服务指标
sysMonitorService.saveBatch(sysMonitors);
//6.使用完删除Token,避免性能差
UserTokenContext.remove();
return ReturnT.SUCCESS;
}
/**
* 获取该模块的Druid指标值
*
* @param module 模块
* @param sysMonitors 集合
* @param webAppStatData
* @param uriStatData
* @param dataSourceStatData
* @param username 用户名
* @param date 当前时间
*/
private void getData(String module, List<Map<String, Object>> methodStatData, List<SysMonitor> sysMonitors, List<Map<String, Object>> webAppStatData, List<Map<String, Object>> uriStatData, List<Map<String, Object>> dataSourceStatData, String username, Date date) {
//请求总数
long requestCount = 0;
//jdbc连接数
long activeCount = 0;
//Session数量
long httpSessionCount = 0;
//SQL 执行数
long logicConnectCount = 0;
//方法执行数
long executeCount = 0;
// ===================================================== spring监控 数据处理 =============================
if (!webAppStatData.isEmpty()) {
executeCount = methodStatData.stream().mapToLong(map -> (long) map.get("ExecuteCount")).sum();
}
// ===================================================== WEB应用监控 数据处理 =============================
if (!webAppStatData.isEmpty()) {
Map<String, Object> webAppStatDatum = webAppStatData.get(0);
requestCount = Long.parseLong(webAppStatDatum.get("RequestCount").toString());
httpSessionCount = Long.parseLong(webAppStatDatum.get("SessionCount").toString());
}
// ===================================================== 数据源监控 数据处理 =============================
if (!dataSourceStatData.isEmpty()) {
//获取master数据源取值
for (Map<String, Object> dataSourceStatDatum : dataSourceStatData) {
if ("master".equals(dataSourceStatDatum.get("Name"))) {
//当前连接池中活跃连接数(当前JDBC 连接数)
activeCount = dataSourceStatDatum.get("ActiveCount") == null ? 0L : Long.parseLong(dataSourceStatDatum.get("ActiveCount").toString());
logicConnectCount = dataSourceStatDatum.get("LogicConnectCount") == null ? 0L : Long.parseLong(dataSourceStatDatum.get("LogicConnectCount").toString());
break;
}
}
}
sysMonitors.add(new SysMonitor(username, module, SysMonitorService.HTTP_SESSION, String.valueOf(httpSessionCount), date));
sysMonitors.add(new SysMonitor(username, module, SysMonitorService.JDBC_ACTIVE, String.valueOf(activeCount), date));
sysMonitors.add(new SysMonitor(username, module, SysMonitorService.JDBC_USED, String.valueOf(logicConnectCount), date));
sysMonitors.add(new SysMonitor(username, module, SysMonitorService.REQUEST_COUNT, String.valueOf(requestCount), date));
sysMonitors.add(new SysMonitor(username, module, SysMonitorService.EXECUTE_COUNT, String.valueOf(executeCount), date));
log.debug("requestCount:" + requestCount);
log.debug("activeCount:" + activeCount);
log.debug("httpSessionCount:" + httpSessionCount);
}
/**
* 获取临时令牌
* <p>
* 模拟登陆接口,获取模拟 Token
*
* @return
*/
public static String getTemporaryToken() {
RedisUtil redisUtil = SpringContextUtils.getBean(RedisUtil.class);
//模拟登录生成临时Token
//参数说明:第一个参数是用户名、第二个参数是密码的加密串
String token = JwtUtil.sign("1", UUID.randomUUID().toString().replace("-", ""));
// 设置Token缓存有效时间为 5 分钟
redisUtil.set(CommonConstant.PREFIX_USER_TOKEN + token, token);
redisUtil.expire(CommonConstant.PREFIX_USER_TOKEN + token, 5 * 60 * 1000);
return token;
}
/**
* 将字节容量转化为GB
*/
public static String transformation(long size) {
return (float) size / 1024 / 1024 / 1024 + "GB" + " ";
}
}
标签:username,org,druid,获取,sysMonitors,监控,import,date,new
From: https://www.cnblogs.com/qwer78/p/16945439.html