【monitor】更新monitor获取服务器信息

pull/3/head
fengshuonan 2021-02-01 20:51:45 +08:00
parent 7bcf1d729e
commit b3da7f3139
14 changed files with 580 additions and 32 deletions

View File

@ -0,0 +1,69 @@
package cn.stylefeng.roses.kernel.monitor.api.pojo;
import cn.hutool.core.util.NumberUtil;
import lombok.Setter;
/**
* CPU
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Setter
public class CpuInfo {
/**
*
*/
private int cpuNum;
/**
* CPU使
*/
private double total;
/**
* CPU使
*/
private double sys;
/**
* CPU使
*/
private double used;
/**
* CPU
*/
private double wait;
/**
* CPU
*/
private double free;
public int getCpuNum() {
return cpuNum;
}
public double getTotal() {
return NumberUtil.round(NumberUtil.mul(total, 100), 2).doubleValue();
}
public double getSys() {
return NumberUtil.round(NumberUtil.mul(sys / total, 100), 2).doubleValue();
}
public double getUsed() {
return NumberUtil.round(NumberUtil.mul(used / total, 100), 2).doubleValue();
}
public double getWait() {
return NumberUtil.round(NumberUtil.mul(wait / total, 100), 2).doubleValue();
}
public double getFree() {
return NumberUtil.round(NumberUtil.mul(free / total, 100), 2).doubleValue();
}
}

View File

@ -0,0 +1,110 @@
package cn.stylefeng.roses.kernel.monitor.api.pojo;
import cn.hutool.core.date.DateUnit;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.NumberUtil;
import lombok.Setter;
import java.lang.management.ManagementFactory;
import java.util.Date;
/**
* JVM
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Setter
public class JvmInfo {
/**
* JVM(M)
*/
private double total;
/**
* JVM(M)
*/
private double max;
/**
* JVM(M)
*/
private double free;
/**
* JDK
*/
private String version;
/**
* JDK
*/
private String home;
public double getTotal() {
return NumberUtil.div(total, (1024 * 1024), 2);
}
public double getMax() {
return NumberUtil.div(max, (1024 * 1024), 2);
}
public double getFree() {
return NumberUtil.div(free, (1024 * 1024), 2);
}
public double getUsed() {
return NumberUtil.div(total - free, (1024 * 1024), 2);
}
public String getVersion() {
return version;
}
public String getHome() {
return home;
}
public double getUsage() {
return NumberUtil.mul(NumberUtil.div(total - free, total, 4), 100);
}
/**
* JDK
*/
public String getName() {
return ManagementFactory.getRuntimeMXBean().getVmName();
}
/**
* JDK
*/
public String getStartTime() {
long time = ManagementFactory.getRuntimeMXBean().getStartTime();
Date date = new Date(time);
return DateUtil.formatDateTime(date);
}
/**
* JDK
*/
public String getRunTime() {
long time = ManagementFactory.getRuntimeMXBean().getStartTime();
Date date = new Date(time);
//运行多少分钟
long runMS = DateUtil.between(date, new Date(), DateUnit.MS);
long nd = 1000 * 24 * 60 * 60;
long nh = 1000 * 60 * 60;
long nm = 1000 * 60;
long day = runMS / nd;
long hour = runMS % nd / nh;
long min = runMS % nd % nh / nm;
return day + "天" + hour + "小时" + min + "分钟";
}
}

View File

@ -0,0 +1,45 @@
package cn.stylefeng.roses.kernel.monitor.api.pojo;
import cn.hutool.core.util.NumberUtil;
import lombok.Setter;
/**
*
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Setter
public class MemInfo {
/**
*
*/
private double total;
/**
*
*/
private double used;
/**
*
*/
private double free;
public double getTotal() {
return NumberUtil.div(total, (1024 * 1024 * 1024), 2);
}
public double getUsed() {
return NumberUtil.div(used, (1024 * 1024 * 1024), 2);
}
public double getFree() {
return NumberUtil.div(free, (1024 * 1024 * 1024), 2);
}
public double getUsage() {
return NumberUtil.mul(NumberUtil.div(used, total, 4), 100);
}
}

View File

@ -0,0 +1,49 @@
package cn.stylefeng.roses.kernel.monitor.api.pojo;
import lombok.Data;
/**
*
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Data
public class SysFileInfo {
/**
*
*/
private String dirName;
/**
*
*/
private String sysTypeName;
/**
*
*/
private String typeName;
/**
*
*/
private String total;
/**
*
*/
private String free;
/**
* 使
*/
private String used;
/**
* 使
*/
private double usage;
}

View File

@ -0,0 +1,39 @@
package cn.stylefeng.roses.kernel.monitor.api.pojo;
import lombok.Data;
/**
*
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Data
public class SysInfo {
/**
*
*/
private String computerName;
/**
* Ip
*/
private String computerIp;
/**
*
*/
private String userDir;
/**
*
*/
private String osName;
/**
*
*/
private String osArch;
}

View File

@ -1 +0,0 @@
监控模块的业务

View File

@ -1,29 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>kernel-o-monitor</artifactId>
<version>1.0.0</version>
<relativePath>../pom.xml</relativePath>
</parent>
<artifactId>monitor-business</artifactId>
<packaging>jar</packaging>
<dependencies>
<!--监控模块的的api-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>monitor-api</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
</project>

View File

@ -24,6 +24,20 @@
<version>1.0.0</version>
</dependency>
<!--定时任务的api-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>timer-api</artifactId>
<version>1.0.0</version>
</dependency>
<!--硬件信息获取-->
<dependency>
<groupId>com.github.oshi</groupId>
<artifactId>oshi-core</artifactId>
<version>${oshi.version}</version>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,200 @@
package cn.stylefeng.roses.kernel.monitor.system;
import cn.hutool.core.net.NetUtil;
import cn.hutool.core.util.NumberUtil;
import cn.stylefeng.roses.kernel.monitor.api.pojo.*;
import cn.stylefeng.roses.kernel.rule.util.IpInfoUtils;
import lombok.Data;
import oshi.SystemInfo;
import oshi.hardware.CentralProcessor;
import oshi.hardware.CentralProcessor.TickType;
import oshi.hardware.GlobalMemory;
import oshi.hardware.HardwareAbstractionLayer;
import oshi.software.os.FileSystem;
import oshi.software.os.OSFileStore;
import oshi.software.os.OperatingSystem;
import oshi.util.Util;
import java.util.LinkedList;
import java.util.List;
import java.util.Properties;
/**
*
*
* @author fengshuonan
* @date 2019-07-13 13:42
*/
@Data
public class SystemHardwareCalculator {
private static final int OSHI_WAIT_SECOND = 1000;
/**
* CPU
*/
private CpuInfo cpu = new CpuInfo();
/**
*
*/
private MemInfo mem = new MemInfo();
/**
* JVM
*/
private JvmInfo jvm = new JvmInfo();
/**
*
*/
private SysInfo sys = new SysInfo();
/**
*
*/
private List<SysFileInfo> sysFiles = new LinkedList<>();
/**
*
*
* @author fengshuonan
* @date 2021/2/1 20:39
*/
public void calc() {
SystemInfo si = new SystemInfo();
HardwareAbstractionLayer hal = si.getHardware();
setCpuInfo(hal.getProcessor());
setMemInfo(hal.getMemory());
setSysInfo();
setJvmInfo();
setSysFiles(si.getOperatingSystem());
}
/**
* CPU
*
* @author fengshuonan
* @date 2021/2/1 20:39
*/
private void setCpuInfo(CentralProcessor processor) {
// CPU信息
long[] prevTicks = processor.getSystemCpuLoadTicks();
Util.sleep(OSHI_WAIT_SECOND);
long[] ticks = processor.getSystemCpuLoadTicks();
long nice = ticks[TickType.NICE.getIndex()] - prevTicks[TickType.NICE.getIndex()];
long irq = ticks[TickType.IRQ.getIndex()] - prevTicks[TickType.IRQ.getIndex()];
long softirq = ticks[TickType.SOFTIRQ.getIndex()] - prevTicks[TickType.SOFTIRQ.getIndex()];
long steal = ticks[TickType.STEAL.getIndex()] - prevTicks[TickType.STEAL.getIndex()];
long cSys = ticks[TickType.SYSTEM.getIndex()] - prevTicks[TickType.SYSTEM.getIndex()];
long user = ticks[TickType.USER.getIndex()] - prevTicks[TickType.USER.getIndex()];
long iowait = ticks[TickType.IOWAIT.getIndex()] - prevTicks[TickType.IOWAIT.getIndex()];
long idle = ticks[TickType.IDLE.getIndex()] - prevTicks[TickType.IDLE.getIndex()];
long totalCpu = user + nice + cSys + idle + iowait + irq + softirq + steal;
cpu.setCpuNum(processor.getLogicalProcessorCount());
cpu.setTotal(totalCpu);
cpu.setSys(cSys);
cpu.setUsed(user);
cpu.setWait(iowait);
cpu.setFree(idle);
}
/**
*
*
* @author fengshuonan
* @date 2021/2/1 20:39
*/
private void setMemInfo(GlobalMemory memory) {
mem.setTotal(memory.getTotal());
mem.setUsed(memory.getTotal() - memory.getAvailable());
mem.setFree(memory.getAvailable());
}
/**
*
*
* @author fengshuonan
* @date 2021/2/1 20:39
*/
private void setSysInfo() {
Properties props = System.getProperties();
sys.setComputerName(IpInfoUtils.getHostName());
sys.setComputerIp(NetUtil.getLocalhostStr());
sys.setOsName(props.getProperty("os.name"));
sys.setOsArch(props.getProperty("os.arch"));
sys.setUserDir(props.getProperty("user.dir"));
}
/**
* Java
*
* @author fengshuonan
* @date 2021/2/1 20:40
*/
private void setJvmInfo() {
Properties props = System.getProperties();
jvm.setTotal(Runtime.getRuntime().totalMemory());
jvm.setMax(Runtime.getRuntime().maxMemory());
jvm.setFree(Runtime.getRuntime().freeMemory());
jvm.setVersion(props.getProperty("java.version"));
jvm.setHome(props.getProperty("java.home"));
}
/**
*
*
* @author fengshuonan
* @date 2021/2/1 20:40
*/
private void setSysFiles(OperatingSystem os) {
FileSystem fileSystem = os.getFileSystem();
OSFileStore[] fsArray = fileSystem.getFileStores();
for (OSFileStore fs : fsArray) {
long free = fs.getUsableSpace();
long total = fs.getTotalSpace();
long used = total - free;
SysFileInfo sysFile = new SysFileInfo();
sysFile.setDirName(fs.getMount());
sysFile.setSysTypeName(fs.getType());
sysFile.setTypeName(fs.getName());
sysFile.setTotal(convertFileSize(total));
sysFile.setFree(convertFileSize(free));
sysFile.setUsed(convertFileSize(used));
if (total == 0) {
sysFile.setUsage(0);
} else {
sysFile.setUsage(NumberUtil.mul(NumberUtil.div(used, total, 4), 100));
}
sysFiles.add(sysFile);
}
}
/**
*
*
* @param size
* @return
* @author fengshuonan
* @date 2021/2/1 20:40
*/
public String convertFileSize(long size) {
long kb = 1024;
long mb = kb * 1024;
long gb = mb * 1024;
if (size >= gb) {
return String.format("%.1f GB", (float) size / gb);
} else if (size >= mb) {
float f = (float) size / mb;
return String.format(f > 100 ? "%.0f MB" : "%.1f MB", f);
} else if (size >= kb) {
float f = (float) size / kb;
return String.format(f > 100 ? "%.0f KB" : "%.1f KB", f);
} else {
return String.format("%d B", size);
}
}
}

View File

@ -0,0 +1,33 @@
package cn.stylefeng.roses.kernel.monitor.system.holder;
import cn.stylefeng.roses.kernel.monitor.system.SystemHardwareCalculator;
import cn.stylefeng.roses.kernel.timer.api.TimerAction;
/**
*
*
* @author fengshuonan
* @date 2021/1/31 21:52
*/
public class SystemHardwareInfoHolder implements TimerAction {
private SystemHardwareCalculator systemHardwareCalculator = null;
@Override
public void action() {
SystemHardwareCalculator newInfo = new SystemHardwareCalculator();
newInfo.calc();
systemHardwareCalculator = newInfo;
}
public SystemHardwareCalculator getSystemHardwareInfo() {
if (systemHardwareCalculator != null) {
return systemHardwareCalculator;
}
systemHardwareCalculator = new SystemHardwareCalculator();
systemHardwareCalculator.calc();
return systemHardwareCalculator;
}
}

View File

@ -20,7 +20,7 @@
<!--监控模块的业务-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>monitor-business</artifactId>
<artifactId>monitor-sdk-system-info</artifactId>
<version>1.0.0</version>
</dependency>

View File

@ -1,5 +1,7 @@
package cn.stylefeng.roses.kernel.monitor.starter;
import cn.stylefeng.roses.kernel.monitor.system.holder.SystemHardwareInfoHolder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
@ -11,5 +13,15 @@ import org.springframework.context.annotation.Configuration;
@Configuration
public class GunsMonitorAutoConfiguration {
/**
* holder
*
* @author fengshuonan
* @date 2021/2/1 20:44
*/
@Bean
public SystemHardwareInfoHolder systemHardwareInfoHolder() {
return new SystemHardwareInfoHolder();
}
}

View File

@ -17,7 +17,6 @@
<modules>
<module>monitor-api</module>
<module>monitor-business</module>
<module>monitor-sdk-system-info</module>
<module>monitor-spring-boot-starter</module>
</modules>

View File

@ -118,6 +118,7 @@
<rocketmq.version>4.5.2</rocketmq.version>
<easy.captcha>1.6.2</easy.captcha>
<groovy.version>3.0.7</groovy.version>
<oshi.version>3.9.1</oshi.version>
</properties>
<dependencyManagement>
@ -270,6 +271,13 @@
<type>pom</type>
</dependency>
<!--硬件信息获取-->
<dependency>
<groupId>com.github.oshi</groupId>
<artifactId>oshi-core</artifactId>
<version>${oshi.version}</version>
</dependency>
</dependencies>
</dependencyManagement>