SpringBoot集成oshi 查询系统数据
实现功能:
<!-- 获取系统信息 --><dependency><groupId>com.github.oshi</groupId><artifactId>oshi-core</artifactId><version>6.6.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.16.1</version></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.14.0</version> <!-- 可替换为最新版本 --></dependency><!-- 解析客户端操作系统、浏览器等 --><dependency><groupId>eu.bitwalker</groupId><artifactId>UserAgentUtils</artifactId><version>1.21</version></dependency>
package com.example.springbootai.entity.server;import com.example.springbootai.utils.Arith;/*** CPU相关信息* * @author caojun*/
public class Cpu
{/*** 核心数*/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 void setCpuNum(int cpuNum){this.cpuNum = cpuNum;}public double getTotal(){return Arith.round(Arith.mul(total, 100), 2);}public void setTotal(double total){this.total = total;}public double getSys(){return Arith.round(Arith.mul(sys / total, 100), 2);}public void setSys(double sys){this.sys = sys;}public double getUsed(){return Arith.round(Arith.mul(used / total, 100), 2);}public void setUsed(double used){this.used = used;}public double getWait(){return Arith.round(Arith.mul(wait / total, 100), 2);}public void setWait(double wait){this.wait = wait;}public double getFree(){return Arith.round(Arith.mul(free / total, 100), 2);}public void setFree(double free){this.free = free;}
}
package com.example.springbootai.entity.server;import com.example.springbootai.utils.Arith;
import com.example.springbootai.utils.DateUtils;import java.lang.management.ManagementFactory;/*** JVM相关信息* * @author caojun*/
public class Jvm
{/*** 当前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 Arith.div(total, (1024 * 1024), 2);}public void setTotal(double total){this.total = total;}public double getMax(){return Arith.div(max, (1024 * 1024), 2);}public void setMax(double max){this.max = max;}public double getFree(){return Arith.div(free, (1024 * 1024), 2);}public void setFree(double free){this.free = free;}public double getUsed(){return Arith.div(total - free, (1024 * 1024), 2);}public double getUsage(){return Arith.mul(Arith.div(total - free, total, 4), 100);}/*** 获取JDK名称*/public String getName(){return ManagementFactory.getRuntimeMXBean().getVmName();}public String getVersion(){return version;}public void setVersion(String version){this.version = version;}public String getHome(){return home;}public void setHome(String home){this.home = home;}/*** JDK启动时间*/public String getStartTime(){return DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD_HH_MM_SS, DateUtils.getServerStartDate());}/*** JDK运行时间*/public String getRunTime(){return DateUtils.timeDistance(DateUtils.getNowDate(), DateUtils.getServerStartDate());}/*** 运行参数*/public String getInputArgs(){return ManagementFactory.getRuntimeMXBean().getInputArguments().toString();}
}
package com.example.springbootai.entity.server;import com.example.springbootai.utils.Arith;/*** 內存相关信息* * @author caojun*/
public class Mem
{/*** 内存总量*/private double total;/*** 已用内存*/private double used;/*** 剩余内存*/private double free;public double getTotal(){return Arith.div(total, (1024 * 1024 * 1024), 2);}public void setTotal(long total){this.total = total;}public double getUsed(){return Arith.div(used, (1024 * 1024 * 1024), 2);}public void setUsed(long used){this.used = used;}public double getFree(){return Arith.div(free, (1024 * 1024 * 1024), 2);}public void setFree(long free){this.free = free;}public double getUsage(){return Arith.mul(Arith.div(used, total, 4), 100);}
}
package com.example.springbootai.entity.server;/*** 系统相关信息* * @author caojun*/
public class Sys
{/*** 服务器名称*/private String computerName;/*** 服务器Ip*/private String computerIp;/*** 项目路径*/private String userDir;/*** 操作系统*/private String osName;/*** 系统架构*/private String osArch;public String getComputerName(){return computerName;}public void setComputerName(String computerName){this.computerName = computerName;}public String getComputerIp(){return computerIp;}public void setComputerIp(String computerIp){this.computerIp = computerIp;}public String getUserDir(){return userDir;}public void setUserDir(String userDir){this.userDir = userDir;}public String getOsName(){return osName;}public void setOsName(String osName){this.osName = osName;}public String getOsArch(){return osArch;}public void setOsArch(String osArch){this.osArch = osArch;}
}
package com.example.springbootai.entity.server;/*** 系统文件相关信息* * @author ruoyi*/
public class SysFile
{/*** 盘符路径*/private String dirName;/*** 盘符类型*/private String sysTypeName;/*** 文件类型*/private String typeName;/*** 总大小*/private String total;/*** 剩余大小*/private String free;/*** 已经使用量*/private String used;/*** 资源的使用率*/private double usage;public String getDirName(){return dirName;}public void setDirName(String dirName){this.dirName = dirName;}public String getSysTypeName(){return sysTypeName;}public void setSysTypeName(String sysTypeName){this.sysTypeName = sysTypeName;}public String getTypeName(){return typeName;}public void setTypeName(String typeName){this.typeName = typeName;}public String getTotal(){return total;}public void setTotal(String total){this.total = total;}public String getFree(){return free;}public void setFree(String free){this.free = free;}public String getUsed(){return used;}public void setUsed(String used){this.used = used;}public double getUsage(){return usage;}public void setUsage(double usage){this.usage = usage;}
}
package com.example.springbootai.entity;import java.net.UnknownHostException;
import java.util.*;import com.example.springbootai.entity.server.*;
import com.example.springbootai.utils.Arith;
import oshi.SystemInfo;
import oshi.hardware.*;
import oshi.hardware.CentralProcessor.TickType;
import oshi.software.os.*;
import oshi.util.Util;/*** 服务器相关信息* * @author caojun*/
public class Server
{private static final int OSHI_WAIT_SECOND = 1000;/*** CPU相关信息*/private Cpu cpu = new Cpu();/*** 內存相关信息*/private Mem mem = new Mem();/*** JVM相关信息*/private Jvm jvm = new Jvm();/*** 服务器相关信息*/private Sys sys = new Sys();/*** 磁盘相关信息*/private List<SysFile> sysFiles = new LinkedList<SysFile>();public Cpu getCpu(){return cpu;}public void setCpu(Cpu cpu){this.cpu = cpu;}public Mem getMem(){return mem;}public void setMem(Mem mem){this.mem = mem;}public Jvm getJvm(){return jvm;}public void setJvm(Jvm jvm){this.jvm = jvm;}public Sys getSys(){return sys;}public void setSys(Sys sys){this.sys = sys;}public List<SysFile> getSysFiles(){return sysFiles;}public void setSysFiles(List<SysFile> sysFiles){this.sysFiles = sysFiles;}public void copyTo() throws Exception{SystemInfo si = new SystemInfo();HardwareAbstractionLayer hal = si.getHardware();setCpuInfo(hal.getProcessor());setMemInfo(hal.getMemory());setSysInfo();setJvmInfo();setSysFiles(si.getOperatingSystem());}/*** 设置CPU信息*/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);}/*** 设置内存信息*/private void setMemInfo(GlobalMemory memory){mem.setTotal(memory.getTotal());mem.setUsed(memory.getTotal() - memory.getAvailable());mem.setFree(memory.getAvailable());}/*** 设置服务器信息*/private void setSysInfo(){Properties props = System.getProperties();sys.setOsName(props.getProperty("os.name"));sys.setOsArch(props.getProperty("os.arch"));sys.setUserDir(props.getProperty("user.dir"));}/*** 设置Java虚拟机*/private void setJvmInfo() throws UnknownHostException{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"));}/*** 设置磁盘信息*/private void setSysFiles(OperatingSystem os){FileSystem fileSystem = os.getFileSystem();List<OSFileStore> fsArray = fileSystem.getFileStores();for (OSFileStore fs : fsArray){long free = fs.getUsableSpace();long total = fs.getTotalSpace();long used = total - free;SysFile sysFile = new SysFile();sysFile.setDirName(fs.getMount());sysFile.setSysTypeName(fs.getType());sysFile.setTypeName(fs.getName());sysFile.setTotal(convertFileSize(total));sysFile.setFree(convertFileSize(free));sysFile.setUsed(convertFileSize(used));sysFile.setUsage(Arith.mul(Arith.div(used, total, 4), 100));sysFiles.add(sysFile);}}/*** 字节转换* * @param size 字节大小* @return 转换后值*/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);}}}
两个工具类
package com.example.springbootai.utils;import java.math.BigDecimal;
import java.math.RoundingMode;/*** 精确的浮点数运算* * @author caojun*/
public class Arith
{/** 默认除法运算精度 */private static final int DEF_DIV_SCALE = 10;/** 这个类不能实例化 */private Arith(){}/*** 提供精确的加法运算。* @param v1 被加数* @param v2 加数* @return 两个参数的和*/public static double add(double v1, double v2){BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.add(b2).doubleValue();}/*** 提供精确的减法运算。* @param v1 被减数* @param v2 减数* @return 两个参数的差*/public static double sub(double v1, double v2){BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.subtract(b2).doubleValue();}/*** 提供精确的乘法运算。* @param v1 被乘数* @param v2 乘数* @return 两个参数的积*/public static double mul(double v1, double v2){BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.multiply(b2).doubleValue();}/*** 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到* 小数点以后10位,以后的数字四舍五入。* @param v1 被除数* @param v2 除数* @return 两个参数的商*/public static double div(double v1, double v2){return div(v1, v2, DEF_DIV_SCALE);}/*** 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指* 定精度,以后的数字四舍五入。* @param v1 被除数* @param v2 除数* @param scale 表示表示需要精确到小数点以后几位。* @return 两个参数的商*/public static double div(double v1, double v2, int scale){if (scale < 0){throw new IllegalArgumentException("The scale must be a positive integer or zero");}BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));if (b1.compareTo(BigDecimal.ZERO) == 0){return BigDecimal.ZERO.doubleValue();}return b1.divide(b2, scale, RoundingMode.HALF_UP).doubleValue();}/*** 提供精确的小数位四舍五入处理。* @param v 需要四舍五入的数字* @param scale 小数点后保留几位* @return 四舍五入后的结果*/public static double round(double v, int scale){if (scale < 0){throw new IllegalArgumentException("The scale must be a positive integer or zero");}BigDecimal b = new BigDecimal(Double.toString(v));BigDecimal one = BigDecimal.ONE;return b.divide(one, scale, RoundingMode.HALF_UP).doubleValue();}
}
package com.example.springbootai.utils;import org.apache.commons.lang3.time.DateFormatUtils;import java.lang.management.ManagementFactory;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.time.*;
import java.util.Date;/*** 时间工具类* * @author caojun*/
public class DateUtils extends org.apache.commons.lang3.time.DateUtils
{public static String YYYY = "yyyy";public static String YYYY_MM = "yyyy-MM";public static String YYYY_MM_DD = "yyyy-MM-dd";public static String YYYYMMDDHHMMSS = "yyyyMMddHHmmss";public static String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";private static String[] parsePatterns = {"yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM", "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM","yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm", "yyyy.MM"};/*** 获取当前Date型日期* * @return Date() 当前日期*/public static Date getNowDate(){return new Date();}/*** 获取当前日期, 默认格式为yyyy-MM-dd* * @return String*/public static String getDate(){return dateTimeNow(YYYY_MM_DD);}public static final String getTime(){return dateTimeNow(YYYY_MM_DD_HH_MM_SS);}public static final String dateTimeNow(){return dateTimeNow(YYYYMMDDHHMMSS);}public static final String dateTimeNow(final String format){return parseDateToStr(format, new Date());}public static final String dateTime(final Date date){return parseDateToStr(YYYY_MM_DD, date);}public static final String parseDateToStr(final String format, final Date date){return new SimpleDateFormat(format).format(date);}public static final Date dateTime(final String format, final String ts){try{return new SimpleDateFormat(format).parse(ts);}catch (ParseException e){throw new RuntimeException(e);}}/*** 日期路径 即年/月/日 如2018/08/08*/public static final String datePath(){Date now = new Date();return DateFormatUtils.format(now, "yyyy/MM/dd");}/*** 日期路径 即年/月/日 如20180808*/public static final String dateTime(){Date now = new Date();return DateFormatUtils.format(now, "yyyyMMdd");}/*** 日期型字符串转化为日期 格式*/public static Date parseDate(Object str){if (str == null){return null;}try{return parseDate(str.toString(), parsePatterns);}catch (ParseException e){return null;}}/*** 获取服务器启动时间*/public static Date getServerStartDate(){long time = ManagementFactory.getRuntimeMXBean().getStartTime();return new Date(time);}/*** 计算相差天数*/public static int differentDaysByMillisecond(Date date1, Date date2){return Math.abs((int) ((date2.getTime() - date1.getTime()) / (1000 * 3600 * 24)));}/*** 计算时间差** @param endDate 最后时间* @param startTime 开始时间* @return 时间差(天/小时/分钟)*/public static String timeDistance(Date endDate, Date startTime){long nd = 1000 * 24 * 60 * 60;long nh = 1000 * 60 * 60;long nm = 1000 * 60;// long ns = 1000;// 获得两个时间的毫秒时间差异long diff = endDate.getTime() - startTime.getTime();// 计算差多少天long day = diff / nd;// 计算差多少小时long hour = diff % nd / nh;// 计算差多少分钟long min = diff % nd % nh / nm;// 计算差多少秒//输出结果// long sec = diff % nd % nh % nm / ns;return day + "天" + hour + "小时" + min + "分钟";}/*** 增加 LocalDateTime ==> Date*/public static Date toDate(LocalDateTime temporalAccessor){ZonedDateTime zdt = temporalAccessor.atZone(ZoneId.systemDefault());return Date.from(zdt.toInstant());}/*** 增加 LocalDate ==> Date*/public static Date toDate(LocalDate temporalAccessor){LocalDateTime localDateTime = LocalDateTime.of(temporalAccessor, LocalTime.of(0, 0, 0));ZonedDateTime zdt = localDateTime.atZone(ZoneId.systemDefault());return Date.from(zdt.toInstant());}
}
package com.example.springbootai;import oshi.SystemInfo;
import oshi.hardware.*;
import oshi.software.os.OSFileStore;
import oshi.software.os.OSProcess;
import oshi.software.os.OperatingSystem;
import oshi.util.FormatUtil;
import oshi.util.Util;import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;/*** @title: test* @Author CaoJun* @Date: 2025/4/18 下午4:40* @Version 1.0*/
public class test {public static void main(String[] args) {SystemInfo si = new SystemInfo();HardwareAbstractionLayer hal = si.getHardware();OperatingSystem os = si.getOperatingSystem();// 1. 操作系统信息printOperatingSystemInfo(os);// 2. 计算机系统信息printComputerSystemInfo(hal.getComputerSystem());// 3. CPU信息printCpuInfo(hal.getProcessor());// 4. 内存信息printMemoryInfo(hal.getMemory());// 5. 磁盘信息printDiskInfo(hal.getDiskStores());// 6. 文件系统信息printFileSystemInfo(os.getFileSystem().getFileStores());// 7. 网络信息printNetworkInfo(hal.getNetworkIFs());// 8. 显卡信息printGraphicsInfo(hal.getGraphicsCards());// 9. 传感器信息printSensorsInfo(hal.getSensors());// 10. 电源信息printPowerInfo(hal.getPowerSources());// 11. 进程信息printProcessInfo(os.getProcesses());}private static void printOperatingSystemInfo(OperatingSystem os) {System.out.println("\n=== 操作系统信息 ===");System.out.println("操作系统: " + os.toString());System.out.println("制造商: " + os.getManufacturer());System.out.println("系列: " + os.getFamily());System.out.println("版本: " + os.getVersionInfo().toString());System.out.println("系统启动时间: " + new Date(os.getSystemBootTime() * 1000L));System.out.println("运行时间: " + FormatUtil.formatElapsedSecs(os.getSystemUptime()));System.out.println("进程数: " + os.getProcessCount());System.out.println("线程数: " + os.getThreadCount());System.out.println("位数: " + (os.getBitness() == 64 ? "64位" : "32位"));}private static void printComputerSystemInfo(ComputerSystem computerSystem) {System.out.println("\n=== 计算机系统信息 ===");System.out.println("制造商: " + computerSystem.getManufacturer());System.out.println("型号: " + computerSystem.getModel());System.out.println("序列号: " + computerSystem.getSerialNumber());Firmware firmware = computerSystem.getFirmware();System.out.println("\n固件信息:");System.out.println(" 制造商: " + firmware.getManufacturer());System.out.println(" 名称: " + firmware.getName());System.out.println(" 描述: " + firmware.getDescription());System.out.println(" 版本: " + firmware.getVersion());System.out.println(" 发布日期: " + (firmware.getReleaseDate() == null ? "未知" : firmware.getReleaseDate()));Baseboard baseboard = computerSystem.getBaseboard();System.out.println("\n主板信息:");System.out.println(" 制造商: " + baseboard.getManufacturer());System.out.println(" 型号: " + baseboard.getModel());System.out.println(" 版本: " + baseboard.getVersion());System.out.println(" 序列号: " + baseboard.getSerialNumber());}private static void printCpuInfo(CentralProcessor processor) {System.out.println("\n=== CPU信息 ===");System.out.println("标识符: " + processor.getProcessorIdentifier().getIdentifier());System.out.println("微架构: " + processor.getProcessorIdentifier().getMicroarchitecture());System.out.println("供应商: " + processor.getProcessorIdentifier().getVendor());System.out.println("系列: " + processor.getProcessorIdentifier().getFamily());System.out.println("型号: " + processor.getProcessorIdentifier().getModel());System.out.println("步进: " + processor.getProcessorIdentifier().getStepping());System.out.println("物理核心数: " + processor.getPhysicalProcessorCount());System.out.println("逻辑核心数: " + processor.getLogicalProcessorCount());System.out.println("最大频率: " + FormatUtil.formatHertz(processor.getMaxFreq()));// CPU负载long[] prevTicks = processor.getSystemCpuLoadTicks();Util.sleep(1000);long[] ticks = processor.getSystemCpuLoadTicks();long user = ticks[CentralProcessor.TickType.USER.getIndex()] - prevTicks[CentralProcessor.TickType.USER.getIndex()];long nice = ticks[CentralProcessor.TickType.NICE.getIndex()] - prevTicks[CentralProcessor.TickType.NICE.getIndex()];long sys = ticks[CentralProcessor.TickType.SYSTEM.getIndex()] - prevTicks[CentralProcessor.TickType.SYSTEM.getIndex()];long idle = ticks[CentralProcessor.TickType.IDLE.getIndex()] - prevTicks[CentralProcessor.TickType.IDLE.getIndex()];long iowait = ticks[CentralProcessor.TickType.IOWAIT.getIndex()] - prevTicks[CentralProcessor.TickType.IOWAIT.getIndex()];long irq = ticks[CentralProcessor.TickType.IRQ.getIndex()] - prevTicks[CentralProcessor.TickType.IRQ.getIndex()];long softirq = ticks[CentralProcessor.TickType.SOFTIRQ.getIndex()] - prevTicks[CentralProcessor.TickType.SOFTIRQ.getIndex()];long steal = ticks[CentralProcessor.TickType.STEAL.getIndex()] - prevTicks[CentralProcessor.TickType.STEAL.getIndex()];long totalCpu = user + nice + sys + idle + iowait + irq + softirq + steal;System.out.println("\nCPU使用情况:");System.out.println(" 用户态: " + formatPercent(user, totalCpu));System.out.println(" 低优先级用户态: " + formatPercent(nice, totalCpu));System.out.println(" 内核态: " + formatPercent(sys, totalCpu));System.out.println(" 空闲: " + formatPercent(idle, totalCpu));System.out.println(" IO等待: " + formatPercent(iowait, totalCpu));System.out.println(" 硬件中断: " + formatPercent(irq, totalCpu));System.out.println(" 软件中断: " + formatPercent(softirq, totalCpu));System.out.println(" 虚拟化等待: " + formatPercent(steal, totalCpu));System.out.println(" 总使用率: " + formatPercent(totalCpu - idle, totalCpu));}private static void printMemoryInfo(GlobalMemory memory) {System.out.println("\n=== 内存信息 ===");System.out.println("总内存: " + FormatUtil.formatBytes(memory.getTotal()));System.out.println("可用内存: " + FormatUtil.formatBytes(memory.getAvailable()));System.out.println("已用内存: " + FormatUtil.formatBytes(memory.getTotal() - memory.getAvailable()));System.out.println("使用率: " + String.format("%.1f%%", (memory.getTotal() - memory.getAvailable()) / (double) memory.getTotal() * 100));}private static void printDiskInfo(List<HWDiskStore> diskStores) {System.out.println("\n=== 磁盘信息 ===");for (HWDiskStore disk : diskStores) {System.out.println("\n磁盘: " + disk.getName());System.out.println(" 型号: " + disk.getModel());System.out.println(" 序列号: " + disk.getSerial());System.out.println(" 大小: " + FormatUtil.formatBytes(disk.getSize()));System.out.println(" 读取次数: " + disk.getReads());System.out.println(" 写入次数: " + disk.getWrites());System.out.println(" 读取字节: " + FormatUtil.formatBytes(disk.getReadBytes()));System.out.println(" 写入字节: " + FormatUtil.formatBytes(disk.getWriteBytes()));System.out.println(" 传输时间(ms): " + disk.getTransferTime());List<HWPartition> partitions = disk.getPartitions();if (partitions != null && !partitions.isEmpty()) {System.out.println(" 分区信息:");for (HWPartition part : partitions) {System.out.println(" 分区: " + part.getIdentification());System.out.println(" 名称: " + part.getName());System.out.println(" 类型: " + part.getType());System.out.println(" 挂载点: " + part.getMountPoint());System.out.println(" 大小: " + FormatUtil.formatBytes(part.getSize()));}}}}private static void printFileSystemInfo(List<OSFileStore> fileStores) {System.out.println("\n=== 文件系统信息 ===");for (OSFileStore fs : fileStores) {System.out.println("\n文件系统: " + fs.getName());System.out.println(" 挂载点: " + fs.getMount());System.out.println(" 描述: " + fs.getDescription());System.out.println(" 类型: " + fs.getType());System.out.println(" 总空间: " + FormatUtil.formatBytes(fs.getTotalSpace()));System.out.println(" 可用空间: " + FormatUtil.formatBytes(fs.getFreeSpace()));System.out.println(" 已用空间: " + FormatUtil.formatBytes(fs.getTotalSpace() - fs.getFreeSpace()));System.out.println(" 使用率: " + String.format("%.1f%%",(fs.getTotalSpace() > 0 ? (double)(fs.getTotalSpace() - fs.getFreeSpace()) / fs.getTotalSpace() * 100 : 0)));System.out.println(" 可读: " + (fs.getUsableSpace() > 0 ? "是" : "否"));System.out.println(" 可写: " + (fs.getUsableSpace() > 0 ? "是" : "否"));}}private static void printNetworkInfo(List<NetworkIF> networkIFs) {System.out.println("\n=== 网络信息 ===");for (NetworkIF net : networkIFs) {System.out.println("\n网络接口: " + net.getName());System.out.println(" 显示名称: " + net.getDisplayName());System.out.println(" MAC地址: " + net.getMacaddr());System.out.println(" IPv4地址: " + Arrays.toString(net.getIPv4addr()));System.out.println(" IPv6地址: " + Arrays.toString(net.getIPv6addr()));System.out.println(" MTU: " + net.getMTU());System.out.println(" 速度: " + (net.getSpeed() > 0 ? FormatUtil.formatValue(net.getSpeed(), "bps") : "未知"));// 获取网络流量统计System.out.println("\n 网络统计:");System.out.println(" 接收字节: " + FormatUtil.formatBytes(net.getBytesRecv()));System.out.println(" 发送字节: " + FormatUtil.formatBytes(net.getBytesSent()));System.out.println(" 接收包数: " + net.getPacketsRecv());System.out.println(" 发送包数: " + net.getPacketsSent());System.out.println(" 接收错误: " + net.getInErrors());System.out.println(" 发送错误: " + net.getOutErrors());// 计算网络速度long[] prevRecv = {net.getBytesRecv()};long[] prevSent = {net.getBytesSent()};Util.sleep(1000);net.updateAttributes();System.out.println("\n 当前速度:");System.out.println(" 接收速度: " + FormatUtil.formatBytes(net.getBytesRecv() - prevRecv[0]) + "/s");System.out.println(" 发送速度: " + FormatUtil.formatBytes(net.getBytesSent() - prevSent[0]) + "/s");}}private static void printGraphicsInfo(List<GraphicsCard> graphicsCards) {System.out.println("\n=== 显卡信息 ===");for (GraphicsCard card : graphicsCards) {System.out.println("\n显卡: " + card.getName());System.out.println(" 设备ID: " + card.getDeviceId());System.out.println(" 供应商: " + card.getVendor());System.out.println(" VRAM: " + FormatUtil.formatBytes(card.getVRam()));System.out.println(" 版本: " + card.getVersionInfo());}}private static void printSensorsInfo(Sensors sensors) {System.out.println("\n=== 传感器信息 ===");System.out.println("CPU温度: " + (sensors.getCpuTemperature() > 0 ?String.format("%.1f°C", sensors.getCpuTemperature()) : "不可用"));System.out.println("CPU电压: " + (sensors.getCpuVoltage() > 0 ?String.format("%.2fV", sensors.getCpuVoltage()) : "不可用"));int[] fanSpeeds = sensors.getFanSpeeds();if (fanSpeeds.length > 0) {System.out.println("风扇转速:");for (int i = 0; i < fanSpeeds.length; i++) {System.out.println(" 风扇" + (i + 1) + ": " + fanSpeeds[i] + " RPM");}} else {System.out.println("风扇转速: 不可用");}}private static void printPowerInfo(List<PowerSource> powerSources) {System.out.println("\n=== 电源信息 ===");if (powerSources.isEmpty()) {System.out.println("没有检测到电源信息");return;}for (PowerSource power : powerSources) {System.out.println("\n电源: " + power.getName());System.out.println(" 设备名称: " + power.getDeviceName());System.out.println(" 是否交流供电: " + (power.isPowerOnLine() ? "是" : "否"));System.out.println(" 是否正在充电: " + (power.isCharging() ? "是" : "否"));System.out.println(" 是否放电中: " + (power.isDischarging() ? "是" : "否"));System.out.println(" 当前容量: " + power.getCurrentCapacity() + " mWh");System.out.println(" 最大容量: " + power.getMaxCapacity() + " mWh");System.out.println(" 设计容量: " + power.getDesignCapacity() + " mWh");System.out.println(" 循环计数: " + power.getCycleCount());System.out.println(" 化学类型: " + power.getChemistry());System.out.println(" 制造日期: " + power.getManufactureDate());System.out.println(" 制造商: " + power.getManufacturer());System.out.println(" 序列号: " + power.getSerialNumber());System.out.println(" 温度: " + power.getTemperature() + "°C");}}private static void printProcessInfo(List<OSProcess> processes) {System.out.println("\n=== 进程信息 ===");System.out.println("总进程数: " + processes.size());}private static String formatPercent(long portion, long total) {return String.format("%.1f%%", total > 0 ? portion * 100d / total : 0);}}
相关文章:
SpringBoot集成oshi 查询系统数据
实现功能: <!-- 获取系统信息 --><dependency><groupId>com.github.oshi</groupId><artifactId>oshi-core</artifactId><version>6.6.1</version></dependency><dependency><groupI…...
iOS Facebook 登录
iOS Facebook 登录 官方文档 SDK下载链接...
uniapp打包IOS私钥证书过期了,如何在非mac系统操作
在非Mac系统下解决uniapp打包iOS私钥证书过期的问题,需通过以下步骤实现: --- ### **一、重新生成iOS证书(非Mac环境操作)** 1. **生成私钥和CSR文件** 使用OpenSSL工具(需提前安装)生成私钥和证书签…...
Axios的使用
Axios 是一个基于 Promise 的现代化 HTTP 客户端库,专为浏览器和 Node.js 设计。在企业级应用中,它凭借以下核心优势成为首选方案: 一、Axios 的核心优势 特性说明Promise 支持天然支持异步编程,避免回调地狱拦截器机制可全局拦截…...
第八篇:系统分析师第三遍——3、4章
目录 一、目标二、计划三、完成情况四、意外之喜(最少2点)1.计划内的明确认知和思想的提升标志2.计划外的具体事情提升内容和标志 五、总结 一、目标 通过参加考试,训练学习能力,而非单纯以拿证为目的。 1.在复习过程中,训练快速阅读能力、掌…...
【2025-泛计算机类-保研/考研经验帖征集】
【2025-泛计算机类-保研/考研经验帖征集】 打扰您1分钟时间看下这里: 这是一个无偿为爱发电的项目,旨在收集湖南大学2025届毕业的计算机类学科同学的经验帖, 我将定期汇总链接,在校内推免群中宣传,为校内的学弟学妹们…...
Flink介绍——实时计算核心论文之Kafka论文详解
引入 我们通过S4和Storm论文的以下文章,已经对S4和Storm有了不错的认识: S4论文详解S4论文总结Storm论文详解Storm论文总结 不过,在讲解这两篇论文的时候,我们其实没有去搞清楚对应的流式数据是从哪里来的。虽然S4里有Keyless …...
细节:如何制作高质量的VR全景图
细节:如何制作高质量的VR全景图 VR全景图是通过虚拟现实和3D技术实现的全景展示方式,能够将实景以1:1的比例等比复刻,并还原到互联网上,使用户能够在线上游览世界,获得沉浸式的体验。制作高质量的VR全景图是一个复杂而…...
深度学习中的概念——元素积(哈达玛积)
元素积操作(哈达玛积) 🔢 基本定义 矩阵的哈达玛积 对于两个同维度的矩阵: A [ a i j ] , B [ b i j ] A [a_{ij}], \quad B [b_{ij}] A[aij],B[bij] 它们的哈达玛积定义为: C A ∘ B 其中 c i j a i j…...
探索 Flowable 后端表达式:简化流程自动化
什么是后端表达式? 在 Flowable 中,后端表达式是一种强大的工具,用于在流程、案例或决策表执行期间动态获取或设置变量。它还能实现自定义逻辑,或将复杂逻辑委托…… 后端表达式在 Flowable 的后端运行,无法访问前端…...
AI语音助手 React 组件使用js-audio-recorder实现,将获取到的语音转成base64发送给后端,后端接口返回文本内容
页面效果: js代码: import React, { useState, useRef, useEffect } from react; import { Layout, List, Input, Button, Avatar, Space, Typography, message } from antd; import { SendOutlined, UserOutlined, RobotOutlined, AudioOutlined, Stop…...
《软件设计师》复习笔记(11.6)——系统转换、系统维护、系统评价
目录 一、遗留系统(Legacy System) 定义: 特点: 演化策略(基于价值与技术评估): 高水平 - 低价值: 高水平 - 高价值: 低水平 - 低价值: 低水平 - 高价…...
学习threejs,使用EffectComposer后期处理组合器(采用RenderPass、GlitchPass渲染通道)
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.EffectComposer 后期…...
Yarn的定义?
YARN(Yet Another Resource Negotiator) 是 Apache Hadoop 的核心组件之一,负责集群的资源管理和任务调度。它的主要作用是将 Hadoop 的资源管理和作业调度/监控功能分离,形成一个通用的资源管理平台,可以支持多种计算…...
职坐标IT培训热门技术实战精讲
在数字化转型浪潮中,人工智能、大数据与云原生已成为驱动产业升级的核心引擎。职坐标IT培训课程以实战导向为基石,聚焦高薪岗位核心技术栈,通过拆解企业级项目案例,将复杂的技术理论转化为可落地的工程实践。课程模块涵盖从架构设…...
前端:uniapp框架中<scroll-view>r如何控制元素进行局部滚动
以下是使用 <scroll-view> 实现局部滚动的完整示例,包含动态内容、滚动控制和滚动位置监听: 一、基础局部滚动示例 <template><view class"container"><!-- 固定高度的滚动容器 --><scroll-view scroll-y :scroll…...
【KWDB 创作者计划】_算法篇---Stockwell变换
文章目录 前言一、Stockwell变换原理详解1.1 连续S变换定义1.2 离散S变换1.3简介 二、S变换的核心特点2.1频率自适应的时频分辨率2.1.1高频区域2.1.2低频区域 2.2无交叉项干扰2.3完全可逆2.4相位保持2.5与傅里叶谱的直接关系 三、应用领域3.1地震信号分析3.2生物医学信号处理3.…...
桌面级OTA测试解决方案:赋能智能网联汽车高效升级
一、前言 随着智能网联汽车的快速发展,OTA(Over-The-Air)技术已成为汽车软件更新和功能迭代的关键手段。为确保OTA升级的可靠性、安全性和效率,构建一套高效、便捷的桌面级OTA测试解决方案至关重要。 本方案基于Vector先进的软硬…...
京东物流基于Flink StarRocks的湖仓建设实践
摘要:本文整理自京东物流高级数据开发工程师梁宝彬先生在 Flink Forward Asia 2024 论坛中的分享。内容主要为以下四个部分: 1、实时湖仓探索与建设 2、实时湖仓应用 3、问题与思考 4、未来展望 今天,将分享的主题大纲包括:首先&a…...
【Test Test】灰度化和二值化处理图像
文章目录 1. 图像灰度化处理对比2. 代码示例3. 二值化处理 1. 图像灰度化处理对比 2. 代码示例 #include <opencv2/opencv.hpp> using namespace cv;int main() {Mat currentImage imread("path_to_image.jpg"); // 读取彩色图像Mat grayImage;// 将彩色图像…...
Docker快速入门
1 基本信息 1.1 基础概览 (1)容器与镜像 容器:轻量级的独立运行时环境,基于Linux的命名空间(namespace)和控制组(cgroup)技术实现资源隔离。容器通过镜像创建,每个容…...
AI 编程工具—如何在 Cursor 中集成使用 MCP工具
AI 编程工具—如何在 Cursor 中集成使用 MCP工具 这里我们给出了常用的MCP 聚合工具,也就是我们可以在这些网站找MCP服务 这是一个MCP Server共享平台,用户可以在上面发布和下载MCP Server配置。在这里可以选择你需要的MCP 服务。 如果你不知道你的mcp 对应的server 名称也不…...
航电系统通信与数据链技术分析
一、技术要点 1. 高带宽与低时延通信技术 航电系统需支持实时数据传输,如民航VDL2数据链采用D8PSK调制和Reed Solomon编码技术,传输速率达31.5Kb/s,并通过物理层优化减少码间串扰。新一代LDACS系统则利用L频段频谱,提供比传统VD…...
windwos脚本 | 基于scrcpy,只投声音、只投画面
安装scrcpy,scrcpy自带adb 写脚本命名为 .bat 结尾 注意这里的set "PATHD:\tools\scrcpy-win64-v3.2;%PATH%" 替换成scrcpy的安装目录 echo off :: 设置UTF-8编码 chcp 65001 > nul :: 设置标题 title 手机投屏工具:: 添加 scrcpy 路径到 PATH set &q…...
产品经理面试题与参考答案资料(2025年版)
一、技术背景与工具能力 问题1: 软件开发生命周期(SDLC)包括哪些阶段?作为产品经理,你如何参与每个阶段? 参考答案: 软件开发生命周期通常划分为需求分析、设计、开发、测试、部署和维护六个阶段。作为产品经理,你需要在...
HTML 初识
段落标签 <p><!-- 段落标签 -->Lorem ipsum dolor sit amet consectetur adipisicing elit. Fugiat, voluptate iure. Obcaecati explicabo sint ipsum impedit! Dolorum omnis voluptas sint unde sed, ipsa molestiae quo sapiente quos et ad reprehenderit.&l…...
CSS3笔记
文章目录 1.CSS的概念2.CSS的引入方式3.选择器3.1基础选择器3.1.1标签选择器3.1.2类选择器3.1.3id选择器3.1.4通配符选择器 4.画盒子5.文字控制属性5.1 字体大小-font-size5.2 字体粗细-font-weight5.3 字体倾斜-font-style5.4 行高-line-height5.5 字体族-font-family5.6 字体…...
yarn的定义
YARN是一个分布式资源管理平台,它通过分离资源管理和作业调度的功能,为Hadoop集群提供了一种高效、灵活且可扩展的方式来管理和分配计算资源。YARN的核心目标是将资源管理与作业调度/监控的功能分离,从而让Hadoop能够支持更多种类的计算框架&…...
CSS 美化页面(五)
一、position属性 属性值描述应用场景static默认定位方式,元素遵循文档流正常排列,top/right/bottom/left 属性无效。普通文档流布局,默认布局,无需特殊定位。relative相对定位,相对于元素原本位置进行偏…...
互联网大厂Java面试:微服务与分布式系统挑战
互联网大厂Java面试:微服务与分布式系统挑战 在互联网的大潮中,无数程序员怀揣着梦想,希望能在一线大厂找到自己的位置。今天的故事主角是马飞机,一位充满幽默感但技术略显水货的程序员。他来到了一家知名互联网公司参加Java开发…...
数据结构——顺序表(C语言实现)
1.顺序表的概述 1.1 顺序表的概念及结构 在了解顺序表之前,我们要先知道线性表的概念,线性表,顾名思义,就是一个线性的且具有n个相同类型的数据元素的有限序列,常见的线性表有顺序表、链表、栈、队列、字符串等等。线…...
FastGPT安装前,系统环境准备工作?
1.启用适用于 Linux 的 Windows 子系统 方法一:打开控制面板 -> 程序 -> 启用或关闭Windows功能->勾选 “适用于Linux的Vindows子系统” 方法二:以管理员身份打开 PowerShell(“开始”菜单 >“PowerShell” >单击右键 >“…...
【2】CICD持续集成-k8s集群中安装Jenkins
一、背景: Jenkins是一款开源 CI&CD 系统,用于自动化各种任务,包括构建、测试和部署。 Jenkins官方提供了镜像:https://hub.docker.com/r/jenkins/jenkins 使用Deployment来部署这个镜像,会暴露两个端口ÿ…...
相比其他缓存/内存数据库(如 Memcached, Ehcache 等),Redis 在微服务环境中的优势和劣势是什么?
我们来比较一下 Redis 与 Memcached、Hazelcast、Ehcache 等在微服务环境下的优势和劣势。 Redis 的优势 : 丰富的数据结构 (Rich Data Structures): 优势: 这是 Redis 最显著的优势之一。除了简单的 Key-Value (字符串) 外,Redis 还原生支持 Lists, Sets, Sorted …...
Day53 二叉树的层序遍历
给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* T…...
mac上安装VMWare Fusion安装ubuntu系统问题
mac不能复制粘贴到虚拟机的ubuntu系统里,没有下载vmtools 在ubuntu系统执行命令 sudo apt update sudo apt install open-vm-tools open-vm-tools-desktop -y ubuntu 下载地址 https://cdimage.ubuntu.com/ubuntu/releases/20.04/release/...
JAVA Web_定义Servlet_处理POST请求【练习】
题目 有一个登录页面(login.html),其登录表单的HTML代码如下: </form action"doLogin" method "post"> 用户名:<input type"text" name"userName"><br>…...
FreeRTOS任务通知
一、什么是任务通知 FreeRTOS从版本V8.2.0开始提供通知这个功能,每个任务都有一个32位的通知值。按照官方说法,使用消息通知比通过二进制信号量方式解除阻塞任务快45%,且更加省内存(无需创建队列)。 (也就…...
NO.97十六届蓝桥杯备战|数论板块-最大公约数和最小公倍数|欧几里得算法|秦九韶算法|小红的gcd(C++)
约数和倍数 如果a 除以b 没有余数,那么a 就是b 的倍数,b 就是a 的约数,记作b ∣ a 。 约数,也称因数。 最⼤公约数和最⼩公倍数 最⼤公约数Greatest Common Divisor,常缩写为gcd。 ⼀组整数的公约数,是…...
ESP32之本地HTTP服务器OTA固件升级流程,基于VSCode环境下的ESP-IDF开发(附源码)
背景知识: 本实验利用编译链内Python内置的 HTTP 服务器,将升级包通过http发送给设备,实现OTA固件升级。 目录 背景知识: 1.创建工程 1.1 创建OTA基础工程 3.编写、修改代码 3.1 修改menuconfig配置文件 3.1.1 配置WiFi账…...
Jenkins的使用及Pipeline语法讲解
Jenkins简介 Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以进行持续集成。 什么是持续集成(CI)? CI(…...
【MySQL】初识数据库
目录 一.什么是数据库 二.数据库和数据结构的关系 三. 数据库服务器、数据库与表之间的关系 四.关系型数据库 五. SQL介绍 SQL分类 六.MySQL架构(面试重点) 七. 库的基本操作 1.查看数据库 2.创建数据库 字符集编码和校验(排序&…...
Android tinyalsa库函数剖析
1. PCM 流控制函数 打开、关闭及状态检查 pcm_open(unsigned int card, unsigned int device, unsigned int flags, struct pcm_config *config) 打开指定声卡(card)和设备(device)的 PCM 流。 flags 参数确定流的方向࿱…...
DFS/BFS专练-搞定图论基础!(从海岛问题过渡至图论基础应用C++/C)
:: 图论基础理论 :: 紧接着,图论基础理论中,咱们讲到,图论的遍历主要由(dfs与bfs决定) 那咱们本篇博客就来聊聊dfs与bfs。 dfs(深度优先搜索)、bfs(广度优先搜索)的区别…...
2024年RIS SCI2区:自适应天鹰算法AAO,深度解析+性能实测
目录 1.摘要2.天鹰算法AO原理3.改进策略4.结果展示5.参考文献6.代码获取 1.摘要 智能电网通过集成可再生能源并管理供需动态平衡来提高效率,本文提出了自适应天鹰算法(AAO),AAO使用Sigmoid因子来平衡探索和开发,根据迭…...
orcad csi 17.4 DRC规则设置及检查
rCAD绘制完原理图之后总是需要开启DRC检测,但是DRC一般都是英文版的,下面基于Cadence17.4 的orCAD16.6 对DRC的界面做简单的介绍 首先,鼠标点击原理图,然后再点击右上方的小勾图标 desine rules check option选项的界面 电气规…...
前端实战:基于 Vue 与 QRCode 库实现动态二维码合成与下载功能
在现代 Web 应用开发中,二维码的应用越来越广泛,从电子票务到信息传递,它都扮演着重要角色。本文将分享如何在 Vue 项目中,结合QRCode库实现动态二维码的生成、与背景图合成以及图片下载功能,打造一个完整且实用的二维…...
天梯赛DFS合集
1.DFS特殊输入:PTA | 程序设计类实验辅助教学平台 这题其他还是蛮容易,直接用递归即可,问题在于怎么输入,其实可以在递归到底层时输入即可,也就是边递归边输入,另外提一嘴跟这个题没什么关系的点ÿ…...
Qt中读写结构体字节数据
在Qt中读写结构体字节数据通常涉及将结构体转换为字节数组(QByteArray)或直接从内存中读写。以下是几种常见方法: 方法1:使用QDataStream读写结构体 cpp #include <QFile> #include <QDataStream>// 定义结构体 #pragma pack(push, 1) //…...
关于yarn和hadoop
1.yarn的定义? YARN(Yet Another Resource Negotiator)是 Apache Hadoop 的一个关键组件,它是一个资源管理平台,负责管理和调度计算资源。YARN 允许多个数据处理引擎(如 MapReduce、Spark、Flink 等&#…...