`

Java如何获取系统信息(包括操作系统、jvm、cpu、内存、硬盘、网络、io等)

阅读更多
 
感觉挺好,收藏一下
Java如何获取系统信息(包括操作系统、jvm、cpu、内存、硬盘、网络、io等),具体所需要插件及操作步骤可查看原文:http://my.oschina.net/mkh/blog/312911
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,内存,硬盘,进程等)的相关方法.pdf

    标题《Java获取系统信息(cpu,内存,硬盘,进程等)的相关方法》揭示了文档主要探讨如何使用Java编程语言获取操作系统底层资源信息,包括CPU、内存、硬盘和进程等。在描述中也提到了这些内容。 首先,要获取Java程序...

    demo_java_DEMO_

    "demo_java_DEMO_"这个项目可能是一个包含了三个示例(Demo)的压缩包,这些示例旨在教授如何利用Java来获取CPU、内存和硬盘等硬件信息。下面我们将详细探讨如何使用Java进行这些操作。 1. **获取CPU信息** 在Java中...

    System.zip

    3. **JVM信息监控**:`java.lang.management.RuntimeMXBean`和`java.lang.management.OperatingSystemMXBean`接口提供了关于JVM和操作系统的详细信息,如JVM启动时间、运行时参数、操作系统版本、CPU使用率等。...

    线上问题调查常用命令

    - **jstat**:用于获取JVM的运行时统计信息,包括堆内存使用情况、GC活动等。 - **jmap**:生成对象和类的内存使用快照,帮助定位内存泄漏等问题。 - **jstack**:获取线程堆栈跟踪信息,可用于分析死锁、挂起等情况...

    Java_cources:对于 Java 中的硬件任务

    9. **硬件监控**: 使用Java的JMX(Java Management Extensions)可以监控系统资源,如CPU、内存、磁盘I/O等,对硬件状态进行实时监测和管理。 10. **图形界面与硬件交互**: Java Swing和JavaFX库提供了丰富的组件和...

    Elasticsearch调优实践

    - **内存调优**:ES需要大量的内存来存储倒排索引,因此,合理分配JVM堆内存至关重要。推荐将60%-80%的可用物理内存分配给JVM,但不要超过32GB,以避免G1垃圾收集器的性能问题。 - **磁盘I/O**:选择SSD硬盘可以...

    apach+tomcat+linux服务器优化指南

    在构建高性能的Web服务时,Apache HTTP Server与Tomcat的组合是常见的选择,尤其是在Linux操作系统上。本指南将深入探讨如何对Apache+Tomcat+Linux环境进行优化,以提升服务器性能、减少资源消耗并增强稳定性。 一...

    Redis面试题 70道.pdf

    以Java为例,使用自带的map 或者guava实现的是本地缓存,最主要的特点是轻量以及快速,生命周期随着jvm的销毁而结束,并且在多实例的情况下,每个实例都需要各自保存一份缓存,缓存不具有一致性。使用Redis 或...

    CS101-homwrok1:th1s 是我为 skool 死记硬背的硬件

    它的设计目标是具有跨平台性,这意味着编写在一种操作系统上的Java程序可以在其他任何支持Java的系统上运行。这得益于Java的“一次编写,到处运行”(Write Once, Run Anywhere)的理念,通过Java虚拟机(JVM)实现。 ...

    redis面试相关问题整理(含答案)

    下面是 Redis 面试相关问题整理,包括概述、持久化、过期键的删除策略、内存相关、事务、集群方案、分区、分布式问题、缓存异常、其他问题等。 概述 Redis 是一个使用 C 语言编写的,开源的(BSD 许可)高性能非...

    Redis常见面试题和答案(最新版).pdf

    - **本地缓存**: 如Java自带的map或Guava,特点是轻量级且速度快,但生命周期随JVM销毁而结束,多实例情况下每个实例需各自保存一份缓存,一致性难以保证。 - **分布式缓存**: 如Redis或Memcached,多实例间共享同一...

    tomcat7优化

    - **服务器资源**:服务器硬件(如CPU、内存和硬盘)的性能对系统的处理能力具有决定性影响。例如,高性能的CPU可以更快地处理请求,而充足的内存则有助于减少磁盘I/O操作,进而提升系统响应速度。 #### 二、Tomcat...

    jsp探针 ver0.1

    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...

Global site tag (gtag.js) - Google Analytics