java获取服务器CPU,内存,硬盘使用量

2024-03-01 06:38

本文主要是介绍java获取服务器CPU,内存,硬盘使用量,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. /** 
  2.  * <获取系统信息类> 
  3.  * <获取系统信息,如CPU、内存、硬盘使用情况> 
  4.  * @author  wenkaixuan 
  5.  * @version  [版本号, 2012-5-9] 
  6.  * @see  [相关类/方法] 
  7.  * @since  [产品/模块版本] 
  8.  */  
  9. public class GetSystemInfo  
  10. {  
  11.     private static final int CPUTIME = 500;  
  12.       
  13.     private static final int PERCENT = 100;  
  14.       
  15.     private static final int FAULTLENGTH = 10;  
  16.       
  17.     //获取内存使用率  
  18.     public static String getMemery()  
  19.     {  
  20.         OperatingSystemMXBean osmxb = (OperatingSystemMXBean)ManagementFactory.getOperatingSystemMXBean();  
  21.         // 总的物理内存+虚拟内存  
  22.         long totalvirtualMemory = osmxb.getTotalSwapSpaceSize();  
  23.         // 剩余的物理内存  
  24.         long freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize();  
  25.         Double compare = (Double)(1 - freePhysicalMemorySize * 1.0 / totalvirtualMemory) * 100;  
  26.         String str = "内存已使用:" + compare.intValue() + "%";  
  27.         return str;  
  28.     }  
  29.       
  30.     //获取文件系统使用率  
  31.     public static List<String> getDisk()  
  32.     {  
  33.         // 操作系统  
  34.         List<String> list = new ArrayList<String>();  
  35.         for (char c = 'A'; c <= 'Z'; c++)  
  36.         {  
  37.             String dirName = c + ":/";  
  38.             File win = new File(dirName);  
  39.             if (win.exists())  
  40.             {  
  41.                 long total = (long)win.getTotalSpace();  
  42.                 long free = (long)win.getFreeSpace();  
  43.                 Double compare = (Double)(1 - free * 1.0 / total) * 100;  
  44.                 String str = c + ":盘  已使用 " + compare.intValue() + "%";  
  45.                 list.add(str);  
  46.             }  
  47.         }  
  48.         return list;  
  49.     }  
  50.       
  51.     //获得cpu使用率  
  52.     public static String getCpuRatioForWindows()  
  53.     {  
  54.         try  
  55.         {  
  56.             String procCmd =  
  57.                 System.getenv("windir")  
  58.                     + "\\system32\\wbem\\wmic.exe process get Caption,CommandLine,KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount";  
  59.             // 取进程信息  
  60.             long[] c0 = readCpu(Runtime.getRuntime().exec(procCmd));  
  61.             Thread.sleep(CPUTIME);  
  62.             long[] c1 = readCpu(Runtime.getRuntime().exec(procCmd));  
  63.             if (c0 != null && c1 != null)  
  64.             {  
  65.                 long idletime = c1[0] - c0[0];  
  66.                 long busytime = c1[1] - c0[1];  
  67.                 return "CPU使用率:" + Double.valueOf(PERCENT * (busytime) * 1.0 / (busytime + idletime)).intValue() + "%";  
  68.             }  
  69.             else  
  70.             {  
  71.                 return "CPU使用率:" + 0 + "%";  
  72.             }  
  73.         }  
  74.         catch (Exception ex)  
  75.         {  
  76.             ex.printStackTrace();  
  77.             return "CPU使用率:" + 0 + "%";  
  78.         }  
  79.     }  
  80.       
  81.     //读取cpu相关信息  
  82.     private static long[] readCpu(final Process proc)  
  83.     {  
  84.         long[] retn = new long[2];  
  85.         try  
  86.         {  
  87.             proc.getOutputStream().close();  
  88.             InputStreamReader ir = new InputStreamReader(proc.getInputStream());  
  89.             LineNumberReader input = new LineNumberReader(ir);  
  90.             String line = input.readLine();  
  91.             if (line == null || line.length() < FAULTLENGTH)  
  92.             {  
  93.                 return null;  
  94.             }  
  95.             int capidx = line.indexOf("Caption");  
  96.             int cmdidx = line.indexOf("CommandLine");  
  97.             int rocidx = line.indexOf("ReadOperationCount");  
  98.             int umtidx = line.indexOf("UserModeTime");  
  99.             int kmtidx = line.indexOf("KernelModeTime");  
  100.             int wocidx = line.indexOf("WriteOperationCount");  
  101.             long idletime = 0;  
  102.             long kneltime = 0;  
  103.             long usertime = 0;  
  104.             while ((line = input.readLine()) != null)  
  105.             {  
  106.                 if (line.length() < wocidx)  
  107.                 {  
  108.                     continue;  
  109.                 }  
  110.                 // 字段出现顺序:Caption,CommandLine,KernelModeTime,ReadOperationCount,  
  111.                 // ThreadCount,UserModeTime,WriteOperation  
  112.                 String caption = substring(line, capidx, cmdidx - 1).trim();  
  113.                 String cmd = substring(line, cmdidx, kmtidx - 1).trim();  
  114.                 if (cmd.indexOf("wmic.exe") >= 0)  
  115.                 {  
  116.                     continue;  
  117.                 }  
  118.                 String s1 = substring(line, kmtidx, rocidx - 1).trim();  
  119.                 String s2 = substring(line, umtidx, wocidx - 1).trim();  
  120.                 if (caption.equals("System Idle Process") || caption.equals("System"))  
  121.                 {  
  122.                     if (s1.length() > 0)  
  123.                         idletime += Long.valueOf(s1).longValue();  
  124.                     if (s2.length() > 0)  
  125.                         idletime += Long.valueOf(s2).longValue();  
  126.                     continue;  
  127.                 }  
  128.                 if (s1.length() > 0)  
  129.                     kneltime += Long.valueOf(s1).longValue();  
  130.                 if (s2.length() > 0)  
  131.                     usertime += Long.valueOf(s2).longValue();  
  132.             }  
  133.             retn[0] = idletime;  
  134.             retn[1] = kneltime + usertime;  
  135.             return retn;  
  136.         }  
  137.         catch (Exception ex)  
  138.         {  
  139.             ex.printStackTrace();  
  140.         }  
  141.         finally  
  142.         {  
  143.             try  
  144.             {  
  145.                 proc.getInputStream().close();  
  146.             }  
  147.             catch (Exception e)  
  148.             {  
  149.                 e.printStackTrace();  
  150.             }  
  151.         }  
  152.         return null;  
  153.     }  
  154.       
  155.     /** 
  156.     * 由于String.subString对汉字处理存在问题(把一个汉字视为一个字节),因此在 包含汉字的字符串时存在隐患,现调整如下: 
  157.     * @param src 要截取的字符串 
  158.     * @param start_idx 开始坐标(包括该坐标) 
  159.     * @param end_idx 截止坐标(包括该坐标) 
  160.     * @return 
  161.     */  
  162.     private static String substring(String src, int start_idx, int end_idx)  
  163.     {  
  164.         byte[] b = src.getBytes();  
  165.         String tgt = "";  
  166.         for (int i = start_idx; i <= end_idx; i++)  
  167.         {  
  168.             tgt += (char)b[i];  
  169.         }  
  170.         return tgt;  
  171.     }  

这篇关于java获取服务器CPU,内存,硬盘使用量的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/761515

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res