感觉挺好,收藏一下
Java如何获取系统信息(包括操作系统、jvm、cpu、内存、硬盘、网络、io等),具体所需要插件及操作步骤可查看原文:http://my.oschina.net/mkh/blog/312911
http://www.thinksaas.cn/topics/0/345/345474.html
import java.net.InetAddress; import java.net.UnknownHostException; import java.util.Map; import java.util.Properties; import org.hyperic.sigar.CpuInfo; import org.hyperic.sigar.CpuPerc; import org.hyperic.sigar.FileSystem; import org.hyperic.sigar.FileSystemUsage; import org.hyperic.sigar.Mem; import org.hyperic.sigar.NetFlags; import org.hyperic.sigar.NetInterfaceConfig; import org.hyperic.sigar.NetInterfaceStat; import org.hyperic.sigar.OperatingSystem; import org.hyperic.sigar.Sigar; import org.hyperic.sigar.SigarException; import org.hyperic.sigar.Swap; import org.hyperic.sigar.Who; public class RuntimeTest { public static void main(String[] args) { try { // System信息,从jvm获取 property(); System.out.println("----------------------------------"); // cpu信息 cpu(); System.out.println("----------------------------------"); // 内存信息 memory(); System.out.println("----------------------------------"); // 操作系统信息 os(); System.out.println("----------------------------------"); // 用户信息 who(); System.out.println("----------------------------------"); // 文件系统信息 file(); System.out.println("----------------------------------"); // 网络信息 net(); System.out.println("----------------------------------"); // 以太网信息 ethernet(); System.out.println("----------------------------------"); } catch (Exception e1) { e1.printStackTrace(); } } private static void property() throws UnknownHostException { Runtime r = Runtime.getRuntime(); Properties props = System.getProperties(); InetAddress addr; addr = InetAddress.getLocalHost(); String ip = addr.getHostAddress(); Map<String, String> map = System.getenv(); String userName = map.get("USERNAME");// 获取用户名 String computerName = map.get("COMPUTERNAME");// 获取计算机名 String userDomain = map.get("USERDOMAIN");// 获取计算机域名 System.out.println("用户名:"+ userName); System.out.println("计算机名:"+ computerName); System.out.println("计算机域名:"+ userDomain); System.out.println("本地ip地址:"+ ip); System.out.println("本地主机名:"+ addr.getHostName()); System.out.println("JVM可以使用的总内存:"+ r.totalMemory()); System.out.println("JVM可以使用的剩余内存:"+ r.freeMemory()); System.out.println("JVM可以使用的处理器个数:"+ r.availableProcessors()); System.out.println("Java的运行环境版本:"+ props.getProperty("java.version")); System.out.println("Java的运行环境供应商:"+ props.getProperty("java.vendor")); System.out.println("Java供应商的URL:"+ props.getProperty("java.vendor.url")); System.out.println("Java的安装路径:"+ props.getProperty("java.home")); System.out.println("Java的虚拟机规范版本:"+ props.getProperty("java.vm.specification.version")); System.out.println("Java的虚拟机规范供应商:"+ props.getProperty("java.vm.specification.vendor")); System.out.println("Java的虚拟机规范名称:"+ props.getProperty("java.vm.specification.name")); System.out.println("Java的虚拟机实现版本:"+ props.getProperty("java.vm.version")); System.out.println("Java的虚拟机实现供应商:"+ props.getProperty("java.vm.vendor")); System.out.println("Java的虚拟机实现名称:"+ props.getProperty("java.vm.name")); System.out.println("Java运行时环境规范版本:"+ props.getProperty("java.specification.version")); System.out.println("Java运行时环境规范供应商:"+ props.getProperty("java.specification.vender")); System.out.println("Java运行时环境规范名称:"+ props.getProperty("java.specification.name")); System.out.println("Java的类格式版本号:"+ props.getProperty("java.class.version")); System.out.println("Java的类路径:"+ props.getProperty("java.class.path")); System.out.println("加载库时搜索的路径列表:"+ props.getProperty("java.library.path")); System.out.println("默认的临时文件路径:"+ props.getProperty("java.io.tmpdir")); System.out.println("一个或多个扩展目录的路径:"+ props.getProperty("java.ext.dirs")); System.out.println("操作系统的名称:"+ props.getProperty("os.name")); System.out.println("操作系统的构架:"+ props.getProperty("os.arch")); System.out.println("操作系统的版本:"+ props.getProperty("os.version")); System.out.println("文件分隔符:"+ props.getProperty("file.separator")); System.out.println("路径分隔符:"+ props.getProperty("path.separator")); System.out.println("行分隔符:"+ props.getProperty("line.separator")); System.out.println("用户的账户名称:"+ props.getProperty("user.name")); System.out.println("用户的主目录:"+ props.getProperty("user.home")); System.out.println("用户的当前工作目录:"+ props.getProperty("user.dir")); } private static void memory() throws SigarException { Sigar sigar = new Sigar(); Mem mem = sigar.getMem(); // 内存总量 System.out.println("内存总量:"+ mem.getTotal() / 1024L +"K av"); // 当前内存使用量 System.out.println("当前内存使用量:"+ mem.getUsed() / 1024L +"K used"); // 当前内存剩余量 System.out.println("当前内存剩余量:"+ mem.getFree() / 1024L +"K free"); Swap swap = sigar.getSwap(); // 交换区总量 System.out.println("交换区总量:"+ swap.getTotal() / 1024L +"K av"); // 当前交换区使用量 System.out.println("当前交换区使用量:"+ swap.getUsed() / 1024L +"K used"); // 当前交换区剩余量 System.out.println("当前交换区剩余量:"+ swap.getFree() / 1024L +"K free"); } private static void cpu() throws SigarException { Sigar sigar = new Sigar(); CpuInfo infos[] = sigar.getCpuInfoList(); CpuPerc cpuList[] = null; cpuList = sigar.getCpuPercList(); for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用 CpuInfo info = infos[i]; System.out.println("第"+ (i + 1) +"块CPU信息"); System.out.println("CPU的总量MHz:"+ info.getMhz());// CPU的总量MHz System.out.println("CPU生产商:"+ info.getVendor());// 获得CPU的卖主,如:Intel System.out.println("CPU类别:"+ info.getModel());// 获得CPU的类别,如:Celeron System.out.println("CPU缓存数量:"+ info.getCacheSize());// 缓冲存储器数量 printCpuPerc(cpuList[i]); } } private static void printCpuPerc(CpuPerc cpu) { System.out.println("CPU用户使用率:"+ CpuPerc.format(cpu.getUser()));// 用户使用率 System.out.println("CPU系统使用率:"+ CpuPerc.format(cpu.getSys()));// 系统使用率 System.out.println("CPU当前等待率:"+ CpuPerc.format(cpu.getWait()));// 当前等待率 System.out.println("CPU当前错误率:"+ CpuPerc.format(cpu.getNice()));// System.out.println("CPU当前空闲率:"+ CpuPerc.format(cpu.getIdle()));// 当前空闲率 System.out.println("CPU总的使用率:"+ CpuPerc.format(cpu.getCombined()));// 总的使用率 } private static void os() { OperatingSystem OS = OperatingSystem.getInstance(); // 操作系统内核类型如: 386、486、586等x86 System.out.println("操作系统:"+ OS.getArch()); System.out.println("操作系统CpuEndian():"+ OS.getCpuEndian());// System.out.println("操作系统DataModel():"+ OS.getDataModel());// // 系统描述 System.out.println("操作系统的描述:"+ OS.getDescription()); // 操作系统类型 // System.out.println("OS.getName():"+ OS.getName()); // System.out.println("OS.getPatchLevel():"+ OS.getPatchLevel());// // 操作系统的卖主 System.out.println("操作系统的卖主:"+ OS.getVendor()); // 卖主名称 System.out.println("操作系统的卖主名:"+ OS.getVendorCodeName()); // 操作系统名称 System.out.println("操作系统名称:"+ OS.getVendorName()); // 操作系统卖主类型 System.out.println("操作系统卖主类型:"+ OS.getVendorVersion()); // 操作系统的版本号 System.out.println("操作系统的版本号:"+ OS.getVersion()); } private static void who() throws SigarException { Sigar sigar = new Sigar(); Who who[] = sigar.getWhoList(); if (who != null && who.length > 0) { for (int i = 0; i < who.length; i++) { // System.out.println("当前系统进程表中的用户名"+ String.valueOf(i)); Who _who = who[i]; System.out.println("用户控制台:"+ _who.getDevice()); System.out.println("用户host:"+ _who.getHost()); // System.out.println("getTime():"+ _who.getTime()); // 当前系统进程表中的用户名 System.out.println("当前系统进程表中的用户名:"+ _who.getUser()); } } } private static void file() throws Exception { Sigar sigar = new Sigar(); FileSystem fslist[] = sigar.getFileSystemList(); for (int i = 0; i < fslist.length; i++) { System.out.println("分区的盘符名称"+ i); FileSystem fs = fslist[i]; // 分区的盘符名称 System.out.println("盘符名称:"+ fs.getDevName()); // 分区的盘符名称 System.out.println("盘符路径:"+ fs.getDirName()); System.out.println("盘符标志:"+ fs.getFlags());// // 文件系统类型,比如 FAT32、NTFS System.out.println("盘符类型:"+ fs.getSysTypeName()); // 文件系统类型名,比如本地硬盘、光驱、网络文件系统等 System.out.println("盘符类型名:"+ fs.getTypeName()); // 文件系统类型 System.out.println("盘符文件系统类型:"+ fs.getType()); FileSystemUsage usage = null; usage = sigar.getFileSystemUsage(fs.getDirName()); switch (fs.getType()) { case 0: // TYPE_UNKNOWN :未知 break; case 1: // TYPE_NONE break; case 2: // TYPE_LOCAL_DISK : 本地硬盘 // 文件系统总大小 System.out.println(fs.getDevName() +"总大小:"+ usage.getTotal() +"KB"); // 文件系统剩余大小 System.out.println(fs.getDevName() +"剩余大小:"+ usage.getFree() +"KB"); // 文件系统可用大小 System.out.println(fs.getDevName() +"可用大小:"+ usage.getAvail() +"KB"); // 文件系统已经使用量 System.out.println(fs.getDevName() +"已经使用量:"+ usage.getUsed() +"KB"); double usePercent = usage.getUsePercent() * 100D; // 文件系统资源的利用率 System.out.println(fs.getDevName() +"资源的利用率:"+ usePercent +"%"); break; case 3:// TYPE_NETWORK :网络 break; case 4:// TYPE_RAM_DISK :闪存 break; case 5:// TYPE_CDROM :光驱 break; case 6:// TYPE_SWAP :页面交换 break; } System.out.println(fs.getDevName() +"读出:"+ usage.getDiskReads()); System.out.println(fs.getDevName() +"写入:"+ usage.getDiskWrites()); } return; } private static void net() throws Exception { Sigar sigar = new Sigar(); String ifNames[] = sigar.getNetInterfaceList(); for (int i = 0; i < ifNames.length; i++) { String name = ifNames[i]; NetInterfaceConfig ifconfig = sigar.getNetInterfaceConfig(name); System.out.println("网络设备名:"+ name);// 网络设备名 System.out.println("IP地址:"+ ifconfig.getAddress());// IP地址 System.out.println("子网掩码:"+ ifconfig.getNetmask());// 子网掩码 if ((ifconfig.getFlags() & 1L) <= 0L) { System.out.println("!IFF_UP...skipping getNetInterfaceStat"); continue; } NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name); System.out.println(name +"接收的总包裹数:"+ ifstat.getRxPackets());// 接收的总包裹数 System.out.println(name +"发送的总包裹数:"+ ifstat.getTxPackets());// 发送的总包裹数 System.out.println(name +"接收到的总字节数:"+ ifstat.getRxBytes());// 接收到的总字节数 System.out.println(name +"发送的总字节数:"+ ifstat.getTxBytes());// 发送的总字节数 System.out.println(name +"接收到的错误包数:"+ ifstat.getRxErrors());// 接收到的错误包数 System.out.println(name +"发送数据包时的错误数:"+ ifstat.getTxErrors());// 发送数据包时的错误数 System.out.println(name +"接收时丢弃的包数:"+ ifstat.getRxDropped());// 接收时丢弃的包数 System.out.println(name +"发送时丢弃的包数:"+ ifstat.getTxDropped());// 发送时丢弃的包数 } } private static void ethernet() throws SigarException { Sigar sigar = null; sigar = new Sigar(); String[] ifaces = sigar.getNetInterfaceList(); for (int i = 0; i < ifaces.length; i++) { NetInterfaceConfig cfg = sigar.getNetInterfaceConfig(ifaces[i]); if (NetFlags.LOOPBACK_ADDRESS.equals(cfg.getAddress()) || (cfg.getFlags() & NetFlags.IFF_LOOPBACK) != 0 || NetFlags.NULL_HWADDR.equals(cfg.getHwaddr())) { continue; } System.out.println(cfg.getName() +"IP地址:"+ cfg.getAddress());// IP地址 System.out.println(cfg.getName() +"网关广播地址:"+ cfg.getBroadcast());// 网关广播地址 System.out.println(cfg.getName() +"网卡MAC地址:"+ cfg.getHwaddr());// 网卡MAC地址 System.out.println(cfg.getName() +"子网掩码:"+ cfg.getNetmask());// 子网掩码 System.out.println(cfg.getName() +"网卡描述信息:"+ cfg.getDescription());// 网卡描述信息 System.out.println(cfg.getName() +"网卡类型"+ cfg.getType());// } } }
http://www.thinksaas.cn/topics/0/345/345474.html
相关推荐
标题《Java获取系统信息(cpu,内存,硬盘,进程等)的相关方法》揭示了文档主要探讨如何使用Java编程语言获取操作系统底层资源信息,包括CPU、内存、硬盘和进程等。在描述中也提到了这些内容。 首先,要获取Java程序...
"demo_java_DEMO_"这个项目可能是一个包含了三个示例(Demo)的压缩包,这些示例旨在教授如何利用Java来获取CPU、内存和硬盘等硬件信息。下面我们将详细探讨如何使用Java进行这些操作。 1. **获取CPU信息** 在Java中...
3. **JVM信息监控**:`java.lang.management.RuntimeMXBean`和`java.lang.management.OperatingSystemMXBean`接口提供了关于JVM和操作系统的详细信息,如JVM启动时间、运行时参数、操作系统版本、CPU使用率等。...
- **jstat**:用于获取JVM的运行时统计信息,包括堆内存使用情况、GC活动等。 - **jmap**:生成对象和类的内存使用快照,帮助定位内存泄漏等问题。 - **jstack**:获取线程堆栈跟踪信息,可用于分析死锁、挂起等情况...
9. **硬件监控**: 使用Java的JMX(Java Management Extensions)可以监控系统资源,如CPU、内存、磁盘I/O等,对硬件状态进行实时监测和管理。 10. **图形界面与硬件交互**: Java Swing和JavaFX库提供了丰富的组件和...
- **内存调优**:ES需要大量的内存来存储倒排索引,因此,合理分配JVM堆内存至关重要。推荐将60%-80%的可用物理内存分配给JVM,但不要超过32GB,以避免G1垃圾收集器的性能问题。 - **磁盘I/O**:选择SSD硬盘可以...
在构建高性能的Web服务时,Apache HTTP Server与Tomcat的组合是常见的选择,尤其是在Linux操作系统上。本指南将深入探讨如何对Apache+Tomcat+Linux环境进行优化,以提升服务器性能、减少资源消耗并增强稳定性。 一...
以Java为例,使用自带的map 或者guava实现的是本地缓存,最主要的特点是轻量以及快速,生命周期随着jvm的销毁而结束,并且在多实例的情况下,每个实例都需要各自保存一份缓存,缓存不具有一致性。使用Redis 或...
它的设计目标是具有跨平台性,这意味着编写在一种操作系统上的Java程序可以在其他任何支持Java的系统上运行。这得益于Java的“一次编写,到处运行”(Write Once, Run Anywhere)的理念,通过Java虚拟机(JVM)实现。 ...
下面是 Redis 面试相关问题整理,包括概述、持久化、过期键的删除策略、内存相关、事务、集群方案、分区、分布式问题、缓存异常、其他问题等。 概述 Redis 是一个使用 C 语言编写的,开源的(BSD 许可)高性能非...
- **本地缓存**: 如Java自带的map或Guava,特点是轻量级且速度快,但生命周期随JVM销毁而结束,多实例情况下每个实例需各自保存一份缓存,一致性难以保证。 - **分布式缓存**: 如Redis或Memcached,多实例间共享同一...
- **服务器资源**:服务器硬件(如CPU、内存和硬盘)的性能对系统的处理能力具有决定性影响。例如,高性能的CPU可以更快地处理请求,而充足的内存则有助于减少磁盘I/O操作,进而提升系统响应速度。 #### 二、Tomcat...
java.io.BufferedReader in = new java.io.BufferedReader(new java.io.InputStreamReader( process.getInputStream())); String freeSpace = "", line; while ((line = in.readLine()) != null) { if (line.length...