`

监控WEB服务器当前系统信息

 
阅读更多
首先给大家介绍一个开源工具Sigar
官网:http://sigar.hyperic.com/
API:http://www.hyperic.com/support/docs/sigar/index-all.html(由于是英文的,英文不好的可以用谷歌浏览器的翻译功能,直接转换为简体中文进行阅读)

Sigar(System Information Gatherer And Reporter),是一个开源的工具,提供了跨平台的系统信息收集的API,由C语言实现的。可以收集的信息包括:

1, CPU信息,包括基本信息(vendor、model、mhz、cacheSize)和统计信息(user、sys、idle、nice、wait)

2, 文件系统信息,包括Filesystem、Size、Used、Avail、Use%、Type

3, 事件信息,类似Service Control Manager

4, 内存信息,物理内存和交换内存的总数、使用数、剩余数;RAM的大小

5, 网络信息,包括网络接口信息和网络路由信息

6, 进程信息,包括每个进程的内存、CPU占用数、状态、参数、句柄

7, IO信息,包括IO的状态,读写大小等

8, 服务状态信息

9, 系统信息,包括操作系统版本,系统资源限制情况,系统运行时间以及负载,JAVA的版本信息等.

Sigar在Java中的使用:
开发时将附件中sigar.rar中的所有文件及jar包放在工程的lib文件夹下。




package com.test_sigar;

import java.net.InetAddress;
import java.net.UnknownHostException;
import java.text.DecimalFormat;

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.SigarNotImplementedException;
import org.hyperic.sigar.Swap;

public class SysInfo {

	public static void main(String [] args) throws Exception{
		SysInfo s =new SysInfo();
		System.out.println("CPU个数:"+s.getCpuCount());
		s.getCpuTotal();
		s.testCpuPerc();
		s.getPhysicalMemory();
		s.testWho();
		s.testFileSystemInfo();
		s.testGetOSInfo();
	}
	/**
	 * 1.CPU资源信息
	 */
	
	// a)CPU数量(单位:个)
	public static int getCpuCount() throws SigarException {
		Sigar sigar = new Sigar();
		try {
			return sigar.getCpuInfoList().length;
		} finally {
			sigar.close();
		}
	}

	// b)CPU的总量(单位:HZ)及CPU的相关信息
	public void getCpuTotal() {
		Sigar sigar = new Sigar();
		CpuInfo[] infos;
		try {
			infos = sigar.getCpuInfoList();
			for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用
				CpuInfo info = infos[i];
				System.out.println("CPU的总量:" + info.getMhz());// CPU的总量MHz
				System.out.println("获得CPU的卖主:" + info.getVendor());// 获得CPU的卖主,如:Intel
				System.out.println("CPU的类别:" + info.getModel());// 获得CPU的类别,如:Celeron
				System.out.println("缓冲存储器数量:" + info.getCacheSize());// 缓冲存储器数量
				System.out.println("**************");
			}
		} catch (SigarException e) {
			e.printStackTrace();
		}
	}

	// c)CPU的用户使用量、系统使用剩余量、总的剩余量、总的使用占用量等(单位:100%)
	public void testCpuPerc() {
		Sigar sigar = new Sigar();
		// 方式一,主要是针对一块CPU的情况
		CpuPerc cpu;
		try {
			cpu = sigar.getCpuPerc();
			printCpuPerc(cpu);
		} catch (SigarException e) {
			e.printStackTrace();
		}
		// 方式二,不管是单块CPU还是多CPU都适用
		CpuPerc cpuList[] = null;
		try {
			cpuList = sigar.getCpuPercList();
		} catch (SigarException e) {
			e.printStackTrace();
			return;
		}
		for (int i = 0; i < cpuList.length; i++) {
			printCpuPerc(cpuList[i]);
		}
	}

	private void printCpuPerc(CpuPerc cpu) {
		System.out.println("用户使用率:" + CpuPerc.format(cpu.getUser()));// 用户使用率
		System.out.println("系统使用率:" + CpuPerc.format(cpu.getSys()));// 系统使用率
		System.out.println("当前等待率:" + CpuPerc.format(cpu.getWait()));// 当前等待率
		System.out.println("Nice :" + CpuPerc.format(cpu.getNice()));//
		System.out.println("当前空闲率:" + CpuPerc.format(cpu.getIdle()));// 当前空闲率
		System.out.println("总的使用率:" + CpuPerc.format(cpu.getCombined()));// 总的使用率
		System.out.println("**************");
	}

	/**
	 * 2.内存资源信息
	 *
	 */
	
	public void getPhysicalMemory() {
		// a)物理内存信息
		DecimalFormat df = new DecimalFormat("#0.00");
		Sigar sigar = new Sigar();
		Mem mem;
		try {
			mem = sigar.getMem();
			// 内存总量
			System.out.println("内存总量:" + df.format((float)mem.getTotal() / 1024/1024/1024) + "G");
			// 当前内存使用量
			System.out.println("当前内存使用量:" + df.format((float)mem.getUsed() / 1024/1024/1024) + "G");
			// 当前内存剩余量
			System.out.println("当前内存剩余量:" + df.format((float)mem.getFree() / 1024/1024/1024) + "G");
			// b)系统页面文件交换区信息
			Swap swap = sigar.getSwap();
			// 交换区总量
			System.out.println("交换区总量:" + df.format((float)swap.getTotal() / 1024/1024/1024) + "G");
			// 当前交换区使用量
			System.out.println("当前交换区使用量:" + df.format((float)swap.getUsed() / 1024/1024/1024) + "G");
			// 当前交换区剩余量
			System.out.println("当前交换区剩余量:" + df.format((float)swap.getFree() / 1024/1024/1024) + "G");
		} catch (SigarException e) {
			e.printStackTrace();
		}
	}

	/**
	 * 3.操作系统信息
	 * 
	 */
	
	// a)取到当前操作系统的名称:
	public String getPlatformName() {
		String hostname = "";
		try {
			hostname = InetAddress.getLocalHost().getHostName();
		} catch (Exception exc) {
			Sigar sigar = new Sigar();
			try {
				hostname = sigar.getNetInfo().getHostName();
			} catch (SigarException e) {
				hostname = "localhost.unknown";
			} finally {
				sigar.close();
			}
		}
		return hostname;
	}

	// b)取当前操作系统的信息
	public void testGetOSInfo() {
		OperatingSystem OS = OperatingSystem.getInstance();
		// 操作系统内核类型如: 386、486、586等x86
		System.out.println("OS.getArch() = " + OS.getArch());
		System.out.println("OS.getCpuEndian() = " + OS.getCpuEndian());//
		System.out.println("OS.getDataModel() = " + OS.getDataModel());//
		// 系统描述
		System.out.println("OS.getDescription() = " + OS.getDescription());
		System.out.println("OS.getMachine() = " + OS.getMachine());//
		// 操作系统类型
		System.out.println("OS.getName() = " + OS.getName());
		System.out.println("OS.getPatchLevel() = " + OS.getPatchLevel());//
		// 操作系统的卖主
		System.out.println("OS.getVendor() = " + OS.getVendor());
		// 卖主名称
		System.out
				.println("OS.getVendorCodeName() = " + OS.getVendorCodeName());
		// 操作系统名称
		System.out.println("OS.getVendorName() = " + OS.getVendorName());
		// 操作系统卖主类型
		System.out.println("OS.getVendorVersion() = " + OS.getVendorVersion());
		// 操作系统的版本号
		System.out.println("OS.getVersion() = " + OS.getVersion());
	}

	// c)取当前系统进程表中的用户信息
	public void testWho() {
		try {
			Sigar sigar = new Sigar();
			org.hyperic.sigar.Who[] who = sigar.getWhoList();
			if (who != null && who.length > 0) {
				for (int i = 0; i < who.length; i++) {
					System.out.println("\n~~~~~~~~~" + String.valueOf(i)
							+ "~~~~~~~~~");
					org.hyperic.sigar.Who _who = who[i];
					System.out.println("获取设备getDevice() = " + _who.getDevice());
					System.out.println("获得主机getHost() = " + _who.getHost());
					System.out.println("获取的时间getTime() = " + _who.getTime());
					// 当前系统进程表中的用户名
					System.out.println("获取用户getUser() = " + _who.getUser());
				}
			}
		} catch (SigarException e) {
			e.printStackTrace();
		}
	}

	// 4.资源信息(主要是硬盘)
	// a)取硬盘已有的分区及其详细信息(通过sigar.getFileSystemList()来获得FileSystem列表对象,然后对其进行编历):
	public void testFileSystemInfo() throws Exception {
		Sigar sigar = new Sigar();
		FileSystem fslist[] = sigar.getFileSystemList();
		DecimalFormat df = new DecimalFormat("#0.00");
		// String dir = System.getProperty("user.home");// 当前用户文件夹路径
		for (int i = 0; i < fslist.length; i++) {
			System.out.println("\n~~~~~~~~~~" + i + "~~~~~~~~~~");
			FileSystem fs = fslist[i];
			// 分区的盘符名称
			System.out.println("fs.getDevName() = " + fs.getDevName());
			// 分区的盘符名称
			System.out.println("fs.getDirName() = " + fs.getDirName());
			System.out.println("fs.getFlags() = " + fs.getFlags());//
			// 文件系统类型,比如 FAT32、NTFS
			System.out.println("fs.getSysTypeName() = " + fs.getSysTypeName());
			// 文件系统类型名,比如本地硬盘、光驱、网络文件系统等
			System.out.println("fs.getTypeName() = " + fs.getTypeName());
			// 文件系统类型
			System.out.println("fs.getType() = " + fs.getType());
			FileSystemUsage usage = null;
			try {
				usage = sigar.getFileSystemUsage(fs.getDirName());
			} catch (SigarException e) {
				if (fs.getType() == 2)
					throw e;
				continue;
			}
			switch (fs.getType()) {
			case 0: // TYPE_UNKNOWN :未知
				break;
			case 1: // TYPE_NONE
				break;
			case 2: // TYPE_LOCAL_DISK : 本地硬盘
				// 文件系统总大小
				System.out.println(" Total = " + df.format((float)usage.getTotal()/1024/1024) + "G");
				// 文件系统剩余大小
				System.out.println(" Free = " + df.format((float)usage.getFree()/1024/1024) + "G");
				// 文件系统可用大小
				System.out.println(" Avail = " + df.format((float)usage.getAvail()/1024/1024) + "G");
				// 文件系统已经使用量
				System.out.println(" Used = " + df.format((float)usage.getUsed()/1024/1024) + "G");
				double usePercent = usage.getUsePercent() * 100D;
				// 文件系统资源的利用率
				System.out.println(" Usage = " + df.format(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(" DiskReads = " + usage.getDiskReads());
			System.out.println(" DiskWrites = " + usage.getDiskWrites());
		}
		return;
	}

	// 5.网络信息
	// a)当前机器的正式域名
	public String getFQDN() {
		Sigar sigar = null;
		try {
			return InetAddress.getLocalHost().getCanonicalHostName();
		} catch (UnknownHostException e) {
			try {
				sigar = new Sigar();
				return sigar.getFQDN();
			} catch (SigarException ex) {
				return null;
			} finally {
				sigar.close();
			}
		}
	}

	// b)取到当前机器的IP地址
	public String getDefaultIpAddress() {
		String address = null;
		try {
			address = InetAddress.getLocalHost().getHostAddress();
			// 没有出现异常而正常当取到的IP时,如果取到的不是网卡循回地址时就返回
			// 否则再通过Sigar工具包中的方法来获取
			if (!NetFlags.LOOPBACK_ADDRESS.equals(address)) {
				return address;
			}
		} catch (UnknownHostException e) {
			// hostname not in DNS or /etc/hosts
		}
		Sigar sigar = new Sigar();
		try {
			address = sigar.getNetInterfaceConfig().getAddress();
		} catch (SigarException e) {
			address = NetFlags.LOOPBACK_ADDRESS;
		} finally {
			sigar.close();
		}
		return address;
	}

	// c)取到当前机器的MAC地址
	public String getMAC() {
		Sigar sigar = null;
		try {
			sigar = new Sigar();
			String[] ifaces = sigar.getNetInterfaceList();
			String hwaddr = null;
			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;
				}
				/*
				 * 如果存在多张网卡包括虚拟机的网卡,默认只取第一张网卡的MAC地址,如果要返回所有的网卡(包括物理的和虚拟的)则可以修改方法的返回类型为数组或Collection
				 * ,通过在for循环里取到的多个MAC地址。
				 */
				hwaddr = cfg.getHwaddr();
				break;
			}
			return hwaddr != null ? hwaddr : null;
		} catch (Exception e) {
			return null;
		} finally {
			if (sigar != null)
				sigar.close();
		}
	}

	// d)获取网络流量等信息
	public void testNetIfList() 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);
			print("\nname = " + name);// 网络设备名
			print("Address = " + ifconfig.getAddress());// IP地址
			print("Netmask = " + ifconfig.getNetmask());// 子网掩码
			if ((ifconfig.getFlags() & 1L) <= 0L) {
				print("!IFF_UP...skipping getNetInterfaceStat");
				continue;
			}
			try {
				NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name);
				print("RxPackets = " + ifstat.getRxPackets());// 接收的总包裹数
				print("TxPackets = " + ifstat.getTxPackets());// 发送的总包裹数
				print("RxBytes = " + ifstat.getRxBytes());// 接收到的总字节数
				print("TxBytes = " + ifstat.getTxBytes());// 发送的总字节数
				print("RxErrors = " + ifstat.getRxErrors());// 接收到的错误包数
				print("TxErrors = " + ifstat.getTxErrors());// 发送数据包时的错误数
				print("RxDropped = " + ifstat.getRxDropped());// 接收时丢弃的包数
				print("TxDropped = " + ifstat.getTxDropped());// 发送时丢弃的包数
			} catch (SigarNotImplementedException e) {
			} catch (SigarException e) {
				print(e.getMessage());
			}
		}
	}

	void print(String msg) {
		System.out.println(msg);
	}

	// e)一些其他的信息
	public void getEthernetInfo() {
		Sigar sigar = null;
		try {
			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.getAddress() = " + cfg.getAddress());// IP地址
				System.out
						.println("cfg.getBroadcast() = " + cfg.getBroadcast());// 网关广播地址
				System.out.println("cfg.getHwaddr() = " + cfg.getHwaddr());// 网卡MAC地址
				System.out.println("cfg.getNetmask() = " + cfg.getNetmask());// 子网掩码
				System.out.println("cfg.getDescription() = "
						+ cfg.getDescription());// 网卡描述信息
				System.out.println("cfg.getType() = " + cfg.getType());//
				System.out.println("cfg.getDestination() = "
						+ cfg.getDestination());
				System.out.println("cfg.getFlags() = " + cfg.getFlags());//
				System.out.println("cfg.getMetric() = " + cfg.getMetric());
				System.out.println("cfg.getMtu() = " + cfg.getMtu());
				System.out.println("cfg.getName() = " + cfg.getName());
				System.out.println();
			}
		} catch (Exception e) {
			System.out.println("Error while creating GUID" + e);
		} finally {
			if (sigar != null)
				sigar.close();
		}
	}

}




转自:http://liningjustsoso.iteye.com/blog/1254584
分享到:
评论

相关推荐

    服务器运行状态监控系统.docx

    对WEB服务器的实时监控,当发现受监控的Web服务器不能正常提供服务时,自动重新启动该服务,使其能够正常运行,并将WEB服务器发生问题的时间和处理信息写入日志文件,以供网络管理人员进行分析。主要提供对Tomcat、...

    服务器运行状态监控系统.doc

    对WEB服务器的实时监控,当发现受监控的Web服务器不能正常提供服务 时,自动重新启动该服务,使其能够正常运行,并将WEB服务器发生问题的时间和处理信 息写入日志文件,以供网络管理人员进行分析。主要提供对Tomcat...

    服务器操作系统维护.docx

    操作系统的安全是信息系统安全的基础,由此加强操作系统维护尤为重要。 服务器的操作系统维护1.采用NTFS文件系统格式 对于微软服务器操作系统而言,NTFS是系统的内核支持,是网络和磁盘配额、文件加密等管理安全特性...

    Zabbix监控系统.docx

    Zabbi监控系统解释 Zabbix是一个基于Web界面提供分布式系统监视及网络监视功能的企业级开源解决方案。它能监视各种网络参数,保证服务器系统的安全运营,并提供灵活的通知机制以让系统管理员快速定位/解决存在的...

    监控系统需求.docx

    监控系统需求全文共2页,当前为第1页。监控系统需求全文共2页,当前为第1页。动环监控需求: 监控系统需求全文共2页,当前为第1页。 监控系统需求全文共2页,当前为第1页。 全市范围内大约1000余机房需要安装动环...

    基于webAndroidspringboot构建服务器端应用智能物流监控系统.zip

    智能物流监控系统是一个前后端分离的项目,前端构建web端应用与Android端应用,后端使用springboot构建服务器端应用,开发API端口与前端交互。服务端使用redis技术缓存数据,可以为分布式系统提供session登录服务,...

    Linuxzabbix+grafana服务器监控系统

    搭建linux服务器监控的目的是自己有一台阿里...当然linux服务器监控也有很多,zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案. ZabbixServer:负责接收agent发送的报告信息的核心组

    IIS网站流量监控软件

    IIS站点流量监控软件是帮助您快速查看一个 IIS 6.0 服务器上的WEB站点流量信息。帮助您实时了解IIS中每个站点具体流量占用情况,如:WEB下载、WEB上传流量、站点当前连接数、站点最大连接数、POST请求数量、站点...

    IIS专家信息监控系统 v1.2

    【IIS专家信息监控系统】是专门针对网站非法信息开发的软件。能及时过滤网页中的非法信息,保障服务器不因非法信息被查封。该软件为永久免费软件,拥有以下功能:1、关键词拦截2、关键词替换3、关键词记录4、SQL注入...

    服务器配置及服务清单.doc

    " "网站访问监控及统计 "自动分析WEB服务器的访问日志,可以按照时间段( " " "小时、日、月)来统计访问数据,可按照参观者的所" " "在地区、操作系统版本、浏览器版本、访问时长等来" " "统计来访用户信息,可...

    远程监控系统方案.docx

    那么如何才能有效掌握这些气井的生产安全状态呢,这就需要借助于一套完整的网络视频监控系统,它是综合计算机IP视频技术、视频和音频数据压缩及解压缩处理技术、互连网应用技术、嵌入式WEB服务器技术相结合的系统。...

    1远程监控系统方案.docx

    那么如何才能有效掌握这些气井的生产安全状态呢,这就需要借助于一套完整的网络视频监控系统,它是综合计算机IP视频技术、视频和音频数据压缩及解压缩处理技术、互连网应用技术、嵌入式WEB服务器技术相结合的系统。...

    SmartVM远程视频监控系统

    5, Smart VM 内置了 Web服务器组件,用户不用再为BS应用去安装传统的IIS, Tomcat 环境等。客户端的组件COM化,支持CS调用,又支持BS调用。 6, Smart VM 加强了报警服务功能,能收集各品牌的视频设备的视频...

    IIS网站流量监控软件(绿色版)

    IIS站点流量监控软件是帮助您快速查看一个 IIS 6.0 / 7.0 服务器上的WEB站点流量信息。帮助您实时了解IIS中每个站点具体流量占用情况,如:WEB下载、WEB上传流量、站点当前连接数、站点最大连接数、POST请求数量、...

    智创IIS网站流量监控软件免费版

    IIS站点流量监控软件是帮助您快速查看一个 IIS 6.0 / 7.0 服务器上的WEB站点流量信息。帮助您实时了解IIS中每个站点具体流量占用情况,如:WEB下载、WEB上传流量、站点当前连接数、站点最大连接数、POST请求数量、...

    网络安全Web的安全概述.pptx

    由于操作系统等方面的漏洞,使得未经授权的用户可以获得Web服务器上的秘密文件和数据,甚至可以对数据进行修改、删除,这是Web站点的一个严重的安全问题。 (2)窃取系统的信息。用户侵入系统内部,获取系统的一些...

    服务器日常巡检表.docx

    7 192.168.10.181 WEB伯俊服务器 8 192.168.10.182 DB服务器/问卷调查 9 192.168.10.183 MAIL SERVER 10 192.168.10.184 文件服务器、门禁、监控 11 192.168.10.194 机房硬盘录像机 12 192.168.10.195 文库系统/投票...

    字符云监控系统v2.5xrkmontor 开源监控系统 支持在线部署.zip

    安装脚本会先检查当前系统是否支持在线安装, 如不支持您可以下载源码后在系统上编译安装 在线部署目前只支持集中部署方式, 即所有服务部署在一台机器上, 该机器上需要安装 mysql/apache 安装脚本使用中文 utf8 ...

Global site tag (gtag.js) - Google Analytics