借助于 Hyperic-Sigar,是一个收集系统各项底层信息的工具集。没啥技术含量。
参考:https://support.hyperic.com/display/SIGAR/Home
下载地址:http://sourceforge.net/projects/sigar/files/sigar/1.6/hyperic-sigar-1.6.4.zip/download
解压后将hyperic-sigar-1.6.4\sigar-bin\lib 下所需的文件拷贝到项目lib下,里面包含两个jar包 和一些其他文件,不同的操作系统使用不同的文件,直接拷贝全部省事。
Maven 依赖信息
<dependency> <groupId>org.fusesource</groupId> <artifactId>sigar</artifactId> <version>1.6.4</version> </dependency>
不多说,直接上代码(Spring MVC的 Controller), 返回json数据,前台页面可灵活调用显示
import java.io.IOException; import java.io.PrintWriter; import javax.servlet.http.HttpServletResponse; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * @author anly * */ public class BaseController { protected Log logger = LogFactory.getLog(getClass()); protected void response2Client (HttpServletResponse response, String content) { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = null; logger.info("response content -->" + content); try { out = response.getWriter(); out.print(content); out.close(); } catch (IOException e) { e.printStackTrace(); } } }
import java.net.InetAddress; import java.net.UnknownHostException; import java.util.Map; import java.util.Properties; import javax.servlet.http.HttpServletResponse; import net.sf.json.JSONArray; import net.sf.json.JSONObject; 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.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import com.anly.common.web.controller.BaseController; /** * @author anly * */ @Controller @RequestMapping(value = "/server") public class ServerInfoController extends BaseController { /** * 服务器信息 */ @RequestMapping(value = "") public void serverInfo(HttpServletResponse response) { Properties props = System.getProperties(); Map<String, String> map = System.getenv(); JSONObject jsonObject = new JSONObject(); jsonObject.put("server.user.name", map.get("USERNAME")); //用户名 jsonObject.put("server.computer.name", map.get("COMPUTERNAME")); //计算机名 jsonObject.put("server.computer.domain", map.get("USERDOMAIN")); //计算机域名 InetAddress addr = null; try { addr = InetAddress.getLocalHost(); jsonObject.put("server.ip", addr.getHostAddress()); //本机ip jsonObject.put("server.host.name", addr.getHostName()); //本机主机名 jsonObject.put("server.user.home", props.getProperty("user.home")); //用户的主目录 jsonObject.put("server.user.dir", props.getProperty("user.dir")); //用户的当前工作目录 } catch (Exception e) { logger.error(e.getMessage()); } super.response2Client(response, jsonObject.toString()); } /** * 系统信息 */ @RequestMapping(value = "/system") public void systemInfo(HttpServletResponse response) { OperatingSystem OS = OperatingSystem.getInstance(); JSONObject jsonObject = new JSONObject(); jsonObject.put("os.name", OS.getVendorName()); //操作系统名称 jsonObject.put("os.arch", OS.getArch()); //内核构架 jsonObject.put("os.description", OS.getDescription()); //操作系统的描述 jsonObject.put("os.version", OS.getVersion()); //操作系统的版本号 super.response2Client(response, jsonObject.toString()); } /** * CPU信息 * @throws SigarException */ @RequestMapping(value = "/cpu") public void cpuInfo(HttpServletResponse response) throws SigarException { Sigar sigar = new Sigar(); CpuInfo infos[] = sigar.getCpuInfoList(); CpuPerc cpuList[] = sigar.getCpuPercList(); JSONObject jsonObject = new JSONObject(); JSONArray jsonArray = new JSONArray(); for (int i = 0, len = infos.length; i < len; i++) {// 不管是单块CPU还是多CPU都适用 CpuInfo info = infos[i]; JSONObject jso = new JSONObject(); jso.put("mhz", info.getMhz()); //CPU的总量MHz jso.put("company", info.getVendor()); //CPU的厂商 jso.put("model", info.getModel()); //CPU型号类别 jso.put("cache.size", info.getCacheSize()); // 缓冲缓存数量 CpuPerc cpu = cpuList[i]; jso.put("freq.user", CpuPerc.format(cpu.getUser())); //CPU的用户使用率 jso.put("freq.sys", CpuPerc.format(cpu.getSys())); //CPU的系统使用率 jso.put("freq.wait", CpuPerc.format(cpu.getWait())); //CPU的当前等待率 jso.put("freq.nice", CpuPerc.format(cpu.getNice())); //CPU的当前错误率 jso.put("freq.idle", CpuPerc.format(cpu.getIdle())); //CPU的当前空闲率 jso.put("freq.combined", CpuPerc.format(cpu.getCombined())); //CPU总的使用率 jsonArray.add(jso); } jsonObject.put("cpu", jsonArray); super.response2Client(response, jsonObject.toString()); } /** * JVM信息 * @throws UnknownHostException */ @RequestMapping(value = "/jvm") public void jvmInfo(HttpServletResponse response) throws UnknownHostException { Runtime r = Runtime.getRuntime(); Properties props = System.getProperties(); JSONObject jsonObject = new JSONObject(); jsonObject.put("jvm.memory.total", r.totalMemory()); //JVM可以使用的总内存 jsonObject.put("jvm.memory.free", r.freeMemory()); //JVM可以使用的剩余内存 jsonObject.put("jvm.processor.avaliable", r.availableProcessors()); //JVM可以使用的处理器个数 jsonObject.put("jvm.java.version", props.getProperty("java.version")); //Java的运行环境版本 jsonObject.put("jvm.java.vendor", props.getProperty("java.vendor")); //Java的运行环境供应商 jsonObject.put("jvm.java.home", props.getProperty("java.home")); //Java的安装路径 jsonObject.put("jvm.java.specification.version", props.getProperty("java.specification.version")); //Java运行时环境规范版本 jsonObject.put("jvm.java.class.path", props.getProperty("java.class.path")); //Java的类路径 jsonObject.put("jvm.java.library.path", props.getProperty("java.library.path")); //Java加载库时搜索的路径列表 jsonObject.put("jvm.java.io.tmpdir", props.getProperty("java.io.tmpdir")); //默认的临时文件路径 jsonObject.put("jvm.java.ext.dirs", props.getProperty("java.ext.dirs")); //扩展目录的路径 super.response2Client(response, jsonObject.toString()); } /** * 内存信息 * @throws SigarException */ @RequestMapping(value = "/memory") public void memoryInfo(HttpServletResponse response) throws SigarException { Sigar sigar = new Sigar(); Mem mem = sigar.getMem(); JSONObject jsonObject = new JSONObject(); jsonObject.put("memory.total", mem.getTotal() / (1024 * 1024L));// 内存总量 jsonObject.put("memory.used", mem.getUsed() / (1024 * 1024L));// 当前内存使用量 jsonObject.put("memory.free", mem.getFree() / (1024 * 1024L));// 当前内存剩余量 Swap swap = sigar.getSwap(); jsonObject.put("memory.swap.total", swap.getTotal() / (1024 * 1024L));// 交换区总量 jsonObject.put("memory.swap.used", swap.getUsed() / (1024 * 1024L));// 当前交换区使用量 jsonObject.put("memory.swap.free", swap.getFree() / (1024 * 1024L));// 当前交换区剩余量 super.response2Client(response, jsonObject.toString()); } /** * 磁盘文件信息 * @throws SigarException */ @RequestMapping(value = "/file") public void fileSystemInfo(HttpServletResponse response) throws SigarException { Sigar sigar = new Sigar(); FileSystem fslist[] = sigar.getFileSystemList(); JSONObject jsonObject = new JSONObject(); JSONArray jsonArray = new JSONArray(); for (int i = 0, len = fslist.length; i < len; i++) { FileSystem fs = fslist[i]; JSONObject jso = new JSONObject(); jso.put("dev.name", fs.getDevName()); //分区盘符名称 jso.put("dir.name", fs.getDirName()); //分区盘符名称 jso.put("flags", fs.getFlags()); //分区盘符类型 jso.put("sys.type.name", fs.getSysTypeName()); //文件系统类型 jso.put("type.name", fs.getTypeName()); //分区盘符类型名 jso.put("type", fs.getType()); //分区盘符文件系统类型 FileSystemUsage usage = null; try { usage = sigar.getFileSystemUsage(fs.getDirName()); } catch (Exception e) { logger.error(e.getMessage()); } if(usage == null) { continue; } switch (fs.getType()) { case 0: // TYPE_UNKNOWN :未知 break; case 1: // TYPE_NONE break; case 2: // TYPE_LOCAL_DISK : 本地硬盘 jso.put("usage.totle", usage.getTotal() / 1024); // 分区总大小 jso.put("usage.free", usage.getFree() / 1024); // 分区剩余大小 jso.put("usage.avail", usage.getAvail() / 1024); // 分区可用大小 jso.put("usage.used", usage.getUsed() / 1024); // 分区已经使用量 jso.put("usage.use.percent", usage.getUsePercent() * 100D); // 分区资源的利用率 break; case 3:// TYPE_NETWORK :网络 break; case 4:// TYPE_RAM_DISK :闪存 break; case 5:// TYPE_CDROM :光驱 break; case 6:// TYPE_SWAP :页面交换 break; } jso.put("disk.reads", usage.getDiskReads()); // 读出 jso.put("disk.writes", usage.getDiskWrites()); // 写入 jsonArray.add(jso); } jsonObject.put("file.system", jsonArray); super.response2Client(response, jsonObject.toString()); } /** * 网络信息 * @throws SigarException */ @RequestMapping(value = "/net") public void netInfo(HttpServletResponse response) throws SigarException { Sigar sigar = new Sigar(); String ifNames[] = sigar.getNetInterfaceList(); JSONObject jsonObject = new JSONObject(); JSONArray jsonArray = new JSONArray(); for (int i = 0, len = ifNames.length; i < len; i++) { String name = ifNames[i]; JSONObject jso = new JSONObject(); NetInterfaceConfig ifconfig = sigar.getNetInterfaceConfig(name); jso.put("name", name); // 网络设备名 jso.put("address", ifconfig.getAddress()); // IP地址 jso.put("mask", ifconfig.getNetmask()); // 子网掩码 if ((ifconfig.getFlags() & 1L) <= 0L) { logger.info("!IFF_UP...skipping getNetInterfaceStat"); continue; } NetInterfaceStat ifstat = sigar.getNetInterfaceStat(name); jso.put("rx.packets", ifstat.getRxPackets());// 接收的总包裹数 jso.put("tx.packets", ifstat.getTxPackets());// 发送的总包裹数 jso.put("rx.bytes", ifstat.getRxBytes());// 接收到的总字节数 jso.put("tx.bytes", ifstat.getTxBytes());// 发送的总字节数 jso.put("rx.errors", ifstat.getRxErrors());// 接收到的错误包数 jso.put("tx.errors", ifstat.getTxErrors());// 发送数据包时的错误数 jso.put("rx.dropped", ifstat.getRxDropped());// 接收时丢弃的包数 jso.put("tx.dropped", ifstat.getTxDropped());// 发送时丢弃的包数 jsonArray.add(jso); } jsonObject.put("net", jsonArray); super.response2Client(response, jsonObject.toString()); } /** * 以太网信息 * @throws SigarException */ @RequestMapping(value = "/ethernet") public void ethernetInfo(HttpServletResponse response) throws SigarException { Sigar sigar = new Sigar(); String[] ifaces = sigar.getNetInterfaceList(); JSONObject jsonObject = new JSONObject(); JSONArray jsonArray = new JSONArray(); for (int i = 0, len = ifaces.length; i < len; 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; } JSONObject jso = new JSONObject(); jso.put("address", cfg.getAddress());// IP地址 jso.put("broad.cast", cfg.getBroadcast());// 网关广播地址 jso.put("hwaddr", cfg.getHwaddr());// 网卡MAC地址 jso.put("net.mask", cfg.getNetmask());// 子网掩码 jso.put("description", cfg.getDescription());// 网卡描述信息 jso.put("type", cfg.getType());// 网卡类型 jsonArray.add(jso); } jsonObject.put("ethernet", jsonArray); super.response2Client(response, jsonObject.toString()); } }
相关推荐
Java实现服务器监控相关代码,使用Maven引入了系统服务jar包. 包含:CPU相关信息、內存相关信息、JVM相关信息、服务器相关信息、磁盘相关信息。 CPU相关信息:核心数 CPU总的使用率 CPU系统使用率 CPU用户使用率等
在"Java 服务器信息监控"项目中,开发者可以编写代码来获取不同操作系统(如Windows、Linux)下的系统资源信息。这些信息包括但不限于CPU利用率、内存使用情况、网络接口状态以及服务运行状态。 首先,让我们关注...
6. **编写RMI客户端**:客户端通过RMI调用服务器端的接口,获取监控信息。这可能涉及到从JMXConnectorServer获取MBean信息,或者直接调用RMI接口。 7. **安全配置**:为了保护远程监控系统,需要进行必要的安全配置...
在Java中获取服务器的基本信息是开发人员经常遇到的需求,这些信息包括但不限于CPU使用情况、内存利用率、磁盘空间以及网络状态等。以下是一些使用Java获取服务器基本信息的关键知识点: 1. **第三方库Sigar**: ...
JavaMelody是一款强大的JAVA Web项目服务器性能监控工具,它能够实时、全面地监控应用程序的运行状态,帮助开发者和运维人员了解系统性能瓶颈,及时发现并解决问题。通过在Java Web应用中简单集成,JavaMelody就能...
内容:Java代码,获取服务器的基本信息(内存,cpu,存储状态等) 适用场景:服务器均可适用,主要是监测服务器的使用状态。 使用方法: 1.添加工程依赖 <!-- 获取系统信息 --> <groupId>...
监控windows内存、cpu、硬盘等各种信息java代码 监控windows内存、cpu、硬盘等各种信息java代码 监控windows内存、cpu、硬盘等各种信息java代码 监控windows内存、cpu、硬盘等各种信息java代码 监控windows内存...
在IT行业中,对服务器资源进行监控是至关重要的,特别是在运行Java应用程序时。"java服务器资源监控脚本.zip"这个压缩包文件提供了一系列工具和脚本,用于帮助我们追踪和分析服务器上的关键性能指标。这些工具通常...
是监控服务器还是监控本地文件夹,通过配置指定。 压缩包里是源代码和所需的jar包,还包括一个已经打成jar文件直接可以运行的文件。 代码有部分参考自互联网,已经做过修正。 根据需求,代码还可以精简。 启动类:dzw...
这可能包括检查服务器的日志文件,分析特定错误代码或异常堆栈信息,或者通过自定义健康检查接口来判断服务是否出现问题。 3. **自动重启**:一旦发现服务异常,监控程序将执行重启操作。这可能涉及调用操作系统...
最后,日志记录是服务器开发中不可或缺的一部分,它有助于调试和监控服务器的运行状态。Java中可以使用Log4j或Java内置的java.util.logging框架进行日志输出。 总结来说,"JAVA简单服务器源代码"涵盖了以下知识点:...
4. **进程监控**:监控服务器上运行的Java进程,包括启动、停止、性能指标等。 5. **网络监控**:检查网络I/O,了解网络延迟和带宽使用情况。 6. **日志监控**:收集和分析应用日志,快速定位错误和异常。 7. **...
根据提供的部分代码示例,我们可以进一步理解如何使用Java实现一个简单的桌面监控程序: 1. **服务器端实现**: - 首先,需要编写一个名为`Server.java`的类文件。 - 使用命令行编译该Java文件:`javac Server....
本项目是基于Java的Phoenix开源监控平台设计源码,共有1306个文件,包括815个Java文件、75个GIF图像文件等。Phoenix是一个灵活可配置的监控平台,能够监控应用程序、服务器、Docker、数据库、网络、TCP端口和HTTP...
这个“java监控开发示例”旨在提供一种方法来实现这一目标,通过Java代码远程监控系统资源,如CPU使用率、内存占用、磁盘空间以及网络状态等。 首先,我们需要理解Java中用于系统监控的基础概念和技术。Java提供了...
5. **代码审查**:根据`jstack.log`中的信息,定位到对应的Java代码,分析可能的问题。常见问题包括无限制的循环、同步块的死锁、CPU密集型的计算或者过多的垃圾收集。 6. **性能监控工具**:除了`jstack`,还可以...
SpringBoot结合Sigar获取服务器监控信息提供restful接口的源代码, 并使用swagger生成接口文档, 包括 CPU信息,服务器基本信息,内存信息, JVM信息,磁盘信息等. 有详细的代码注释.
获取linux服务器内存,cpu,硬盘等信息java代码,sigar实现!
在Java IPMI和VxIPMI中,你可以通过以下步骤获取服务器信息: 1. **建立连接**:首先,你需要通过Java程序建立到目标服务器的IPMI连接。这通常涉及设置服务器的IP地址、端口、用户名和密码。VxIPMI库可能提供了一种...
- JConsole:Java自带的图形化监控工具,可以查看JVM内存、线程、类加载、垃圾回收等信息。 - VisualVM:集成了多种JDK自带的诊断工具,提供更丰富的性能数据,如CPU、内存、线程快照等。 - JProfiler:一款强大...