`
avery_leo
  • 浏览: 388362 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

用java取得linux系统cpu、内存的实时信息

阅读更多
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

/**
* 取得linux系统下的cpu、mem信息
* 
* */
public final class LinuxSystemTool
{
      public static int[] getMemInfo() throws IOException, InterruptedException
   {
      File file = new File("/proc/meminfo");
      BufferedReader br = new BufferedReader(new InputStreamReader(
      new FileInputStream(file)));
      int[] result = new int[4];
      String str = null;
      StringTokenizer token = null;
      while((str = br.readLine()) != null)
      {
         token = new StringTokenizer(str);
         if(!token.hasMoreTokens())
            continue;
   
         str = token.nextToken();
         if(!token.hasMoreTokens())
            continue;
   
         if(str.equalsIgnoreCase("MemTotal:"))
            result[0] = Integer.parseInt(token.nextToken());
         else if(str.equalsIgnoreCase("MemFree:"))
            result[1] = Integer.parseInt(token.nextToken());
         else if(str.equalsIgnoreCase("SwapTotal:"))
            result[2] = Integer.parseInt(token.nextToken());
         else if(str.equalsIgnoreCase("SwapFree:"))
            result[3] = Integer.parseInt(token.nextToken());
      }
   
      return result;
   }

     public static float getCpuInfo() throws IOException, InterruptedException
   {
      File file = new File("/proc/stat");
      BufferedReader br = new BufferedReader(new InputStreamReader(
      new FileInputStream(file)));
      StringTokenizer token = new StringTokenizer(br.readLine());
      token.nextToken();
      int user1 = Integer.parseInt(token.nextToken());
      int nice1 = Integer.parseInt(token.nextToken());
      int sys1 = Integer.parseInt(token.nextToken());
      int idle1 = Integer.parseInt(token.nextToken());
   
      Thread.sleep(1000);

      br = new BufferedReader(
      new InputStreamReader(new FileInputStream(file)));
      token = new StringTokenizer(br.readLine());
      token.nextToken();
      int user2 = Integer.parseInt(token.nextToken());
      int nice2 = Integer.parseInt(token.nextToken());
      int sys2 = Integer.parseInt(token.nextToken());
      int idle2 = Integer.parseInt(token.nextToken());

      return (float)((user2 + sys2 + nice2) - (user1 + sys1 + nice1)) / (float)((user2 + nice2 + sys2 + idle2) - (user1 + nice1 + sys1 + idle1));
   }
}

/**
* 测试类
* 
* @date 2007
*/
public class PpUtil
{
    public static void main(String[] args) throws Exception
    {
        int[] memInfo = LinuxSystemTool.getMemInfo();
        System.out.println("MemTotal:" + memInfo[0]);
        System.out.println("MemFree:" + memInfo[1]);
        System.out.println("SwapTotal:" + memInfo[2]);
        System.out.println("SwapFree:" + memInfo[3]);

        System.out.println("CPUused:" + LinuxSystemTool.getCpuInfo());
    }
}

 (http://people.ee.ethz.ch/~oetiker/webtools/mrtg/)就是一个很不错的选择。不过用mrtg就要装sysstat、apache、snmp、perl之类的东西。而且安装也要好几个步骤,似乎比较麻烦。本来也想直接调用sar、vmstat之类的命令,parse一下结果就算了。哪知道发现不同的版本的linux这些命令的结果也都是不一样。既然要按版本 parse它们的结果,那还不如直接去系统里面获得算了。于是研究了一下sysstat(http://freshmeat.net/projects/sysstat/)和gkrellm(http://gkrellm.net )的源代码,找到监测性能的数据所在。

 

1、CPU

 

在文件"/proc/stat"里面就包含了CPU的信息。每一个CPU的每一tick用在什么地方都在这个文件里面记着。后面的数字含义分别是: user、nice、sys、idle、iowait。有些版本的kernel没有iowait这一项。这些数值表示从开机到现在,CPU的每tick用在了哪里。例如:

cpu0 256279030 0 11832528 1637168262

就是cpu0从开机到现在有 256279030 tick用在了user消耗,11832528用在了sys消耗。所以如果想计算单位时间(例如1s)里面CPU的负载,那只需要计算1秒前后数值的差除以每一秒的tick数量就可以了。gkrellm就是这样实现的:((200 * (v2 - v1) / CPU_TICKS_PER_SECOND) + 1) /2

例如,第一次读取/proc/stat,user的值是256279030;一秒以后再读一次,值是256289030,那么CPU在这一秒的user消耗就是:((200 * (256289030 - 256279030) / CPU_TICKS_PER_SECOND) + 1) /2 = ((10000 * 200 / 1000000) + 1) / 2 = 1%了。

 

2、内存消耗

 

文件"/proc/meminfo"里面包含的就是内存的信息,还包括了swap的信息。例如:

 

 

[root@dxot leo]# cat /proc/meminfo
        total:    used:    free:  shared: buffers:  cached:
Mem:  524218368 501383168 22835200        0 122474496 170418176
Swap: 2146787328 158924800 1987862528
MemTotal:       511932 kB
MemFree:         22300 kB
MemShared:           0 kB
Buffers:        119604 kB
Cached:          81392 kB
SwapCached:      85032 kB
Active:         363964 kB
ActiveAnon:     235048 kB
ActiveCache:    128916 kB
Inact_dirty:     71132 kB
Inact_laundry:   14848 kB
Inact_clean:      6788 kB
Inact_target:    91344 kB
HighTotal:           0 kB
HighFree:            0 kB
LowTotal:       511932 kB
LowFree:         22300 kB
SwapTotal:     2096472 kB
SwapFree:      1941272 kB
HugePages_Total:     0
HugePages_Free:      0
Hugepagesize:     4096 kB

不过从gkrellm的源代码看,有些版本没有前面那两行统计的信息,只能够根据下面的Key: Value这种各式的数据收集。

 

3、磁盘空间

 

从gkrellm的源代码看,这个是一个很复杂的数据。磁盘分区的数据有可能分布在:/proc/mounts、/proc/diskstats、 /proc/partitions等等。而且如果想要检查某几个特定的路径,还需要通过mount、df等命令的帮助。为了减少麻烦,这个数据我就直接用 statfs函数直接获得了。

 

int statfs(const char *path, struct statfs *buf);

这个函数只需要输入需要检查的路径名称,就可以返回这个路径所在的分区的空间使用情况:

总空间:buf.f_bsize * buf.f_blocks

空余空间:buf.f_bsize * buf.f_bavail

 

4、磁盘I/O

 

磁盘I/O的数据也同样比较复杂,有些版本看/proc/diskstats,有些版本看/proc/partitions,还有些版本至今我也不知道在那里看……不过可以看到数据的版本也像CPU那样,需要隔一段时间取值,两次取值的差就是流量。

 

5、网络流量

 

网络流量也是五花八门,不过基本上都可以在/proc/net/dev里面获得。同样也是需要两次取值取其差作为流量值。

Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论

分享到:
评论
2 楼 zhanjia 2008-10-25  
谢谢提供, 正需要
1 楼 chixianhuadeyu 2008-08-01  
真是哥们 我这些天正在收集这些资料

相关推荐

    基于Linux网络计算机Java虚拟机的性能优化.pdf

    针对这一挑战,一种优化策略是在Kaffe虚拟机中应用和改进直接线索式解释器优化技术,以适应Linux NC的硬件配置和软件模式,同时确保较低的CPU和内存成本,从而提升Java虚拟机的运行效率。 网络计算机(NC)是网络...

    JAVA上百实例源码以及开源项目源代码

    Java编写的显示器显示模式检测程序 2个目标文件 内容索引:JAVA源码,系统相关,系统信息检测 用JAVA编写了一个小工具,用于检测当前显示器也就是显卡的显示模式,比如分辨率,色彩以及刷新频率等。 Java波浪文字制作...

    Linux 嵌入式应用程序的开发

    开发者需掌握如何优化代码以减少CPU使用率,提高实时性能,并降低功耗。 7. **调试技术**:在没有标准桌面环境的嵌入式系统中,调试工具如GDB、JTAG和串行端口通信是必不可少的。学会使用这些工具能有效定位和解决...

    Linux线程库: NPTL

    - **内存使用效率**:NPTL在内存管理和使用方面更加高效。 - **锁机制**:NPTL改进了锁机制,减少了死锁的可能性。 #### 四、结论 NPTL作为下一代线程库,不仅解决了原有LTT库的一些关键问题,还在性能和标准化...

    java前期总结(面向对象及之前)

    系统软件如Windows、Linux等操作系统;应用软件则包括Word、QQ等用户直接使用的程序。 **1.1.2 计算机语言** 计算机语言用于编写程序,以便计算机能够理解和执行任务。常见的计算机语言包括C、C++、Java等。此外,...

    软考 嵌入式系统设计师

    2. 操作系统:嵌入式系统通常运行实时操作系统(RTOS),如FreeRTOS、VxWorks或Linux的实时内核。设计师应熟悉操作系统的调度策略、中断处理、多任务管理以及内存管理机制。 3. 软件开发:编程语言如C和C++是嵌入式...

    信息处理技术员教程 唐多强.7z

    这包括计算机系统的组成原理,如CPU、内存、存储设备等;操作系统的基本概念,如Windows、Linux等;以及数据通信和网络基础,如TCP/IP协议、局域网与广域网技术。 2. **中册**:可能深入到数据库管理与编程语言。这...

    2万字Java并发编程面试题合集(含答案,建议收藏)

    进程则是系统分配资源的基本单位,每个进程有自己的独立内存空间。 3. **上下文切换**:多线程中的上下文切换是指操作系统在执行线程时保存和恢复其上下文的过程,以便在将来恢复执行。 4. **死锁与活锁、饥饿的...

    深大 计系二 复习提纲.pdf

    计算机硬件是计算机系统的基础组成部分,它包括CPU、内存、硬盘、I/O接口等。CPU(中央处理单元)是计算机的核心部件,负责解释和执行指令。内存(如RAM)是临时存储正在执行程序的存储器,用于存储临时数据和程序...

    宁波波导软件有限公司笔试题

    2. 实时操作系统(RTOS):了解FreeRTOS、VxWorks等常见RTOS的工作原理和API使用。 3. Linux内核:理解Linux内核模块、设备驱动、中断处理等。 四、数据结构与算法: 1. 基本数据结构:数组、链表、栈、队列、树、...

    信息处理技术员提分必备知识点_信息处理技术员提分必备知识点_

    1. **计算机基础知识**:首先,你需要理解计算机硬件的构成,包括CPU(中央处理器)、内存(RAM)、硬盘、显示器等,以及它们如何协同工作。还要了解操作系统的基本功能,如资源管理、任务调度和用户界面。 2. **...

    android开发关键技术之旅

    - 性能监控:使用Android Profiler分析内存、CPU和网络使用情况,优化代码性能。 通过这个压缩包提供的项目代码,您可以逐步地跟随实践,从零开始构建一个完整的Android应用。这将帮助您巩固理论知识,提高解决...

    一年计算机一级B考试复习提纲.pdf

    计算机一级B考试复习提纲涵盖了信息技术基础、计算机硬件、软件、操作系统、计算机网络等多个方面的内容。以下是这些知识点的详细说明: 一、信息技术基础 1. 信息技术:涉及信息的获取、处理、存储、传播和应用的...

    下半年全国统考教师资格考试《信息技术学科知识与教学能力》复习全书.docx

    面,考生需要了解计算机硬件的基本组成,如中央处理器(CPU)、内存(RAM)、硬盘(HDD/SSD)、输入输出设备等,以及它们在计算机工作中的作用。在计算机网络部分,要掌握网络通信协议(如TCP/IP)、网络拓扑结构、...

    江苏专转本计算机基础各章知识点含习题试卷.pdf

    任务管理中的进程管理涉及CPU的调度,而虚拟存储器则允许扩展内存容量。文件系统是所有程序、数据和文档的存储载体。 常见的操作系统有Windows系列,如Windows 9X、NT、2000、XP、Vista等,这些系统具有图形用户...

    青鸟学员S1复习资料

    2. 操作系统原理:S1复习资料可能包含Windows、Linux或Mac OS等常见操作系统的使用和管理知识,包括文件管理、用户权限、进程管理、任务调度等。了解操作系统的运行机制对解决实际问题至关重要。 3. 网络技术:网络...

    公务员计算机专业考试

    1. 计算机基础知识:这部分内容包括计算机的发展历程、计算机系统的组成(如CPU、内存、硬盘等)、数据的存储单位(如比特、字节等)、计算机工作原理以及计算机软件和硬件的基本概念。 2. 操作系统:操作系统是...

    计算机研究

    根据给定的信息,“计算机研究”这一主题主要面向的是计算机科学领域的初学者,旨在提供一份易于理解且实用性强的入门指南。下面将从计算机基础知识、硬件组成、操作系统介绍、编程语言入门等多个方面进行详细阐述,...

Global site tag (gtag.js) - Google Analytics