成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

通過/proc/stat文件信息,java實現計算cpu使用率

開發 后端
通過/proc/stat文件信息,java實現計算cpu使用率。了解/proc/stat 內容,一步一步進行代碼編寫。

/proc/stat 文件內容:

  1. [root@Shentar ~]# cat /proc/stat 
  2. cpu  602 0 2164 11445 2294 0 17 0 0 
  3. cpu0 306 0 1232 4553 2125 0 15 0 0 
  4. cpu1 295 0 932 6891 169 0 1 0 0 
  5. intr 7110 269 7 0 1 1 0 5 0 1 0 0 0 91 0 0 106 0 6521 0 108 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
  6. ctxt 38984 
  7. btime 1368275792 
  8. processes 2713 
  9. procs_running 1 
  10. procs_blocked 0 
  11. [root@Shentar ~]#  

***行的數值表示的是CPU總的使用情況,所以我們只要用***行的數字計算就可以了。下表解析***行各數值的含義:

參數 解析(單位:jiffies)

(jiffies是內核中的一個全局變量,用來記錄自系統啟動一來產生的節拍數,在linux中,一個節拍大致可理解為操作系統進程調度的最小時間片,不同linux內核可能值有不同,通常在1ms到10ms之間)

user (38082) 從系統啟動開始累計到當前時刻,處于用戶態的運行時間,不包含 nice值為負進程。

nice (627) 從系統啟動開始累計到當前時刻,nice值為負的進程所占用的CPU時間

system (27594) 從系統啟動開始累計到當前時刻,處于核心態的運行時間

idle (893908) 從系統啟動開始累計到當前時刻,除IO等待時間以外的其它等待時間iowait (12256) 從系統啟動開始累計到當前時刻,IO等待時間(since 2.5.41)

irq (581) 從系統啟動開始累計到當前時刻,硬中斷時間(since 2.6.0-test4)

softirq (895) 從系統啟動開始累計到當前時刻,軟中斷時間(since 2.6.0-test4)stealstolen(0) which is the time spent in other operating systems when running in a virtualized environment(since 2.6.11)

guest(0) which is the time spent running a virtual CPU for guest operating systems under the control of the Linux kernel(since 2.6.24)

結論:總的cpu時間totalCpuTime = user + nice + system + idle + iowait + irq + softirq + stealstolen + guest

計算時,采樣兩個時間點的數據,對于時間點1,記錄總的cpu時間total1,記錄空閑時間idle1,對于時間2,同樣記錄total2和idle2。

菜譜使用率為:cpuusage = 1 – (idle2 – idle1) / (total2 – total1)

注意,如果時間點1和時間點2間隔足夠?。ㄐ∮?0ms),則可能出現total2 – total1為0,這樣cpu使用率應該為0,而不是采用除法計算。

java代碼如下:

CPUUsage.java

  1. package com; 
  2.  
  3. import java.io.BufferedReader; 
  4. import java.io.File; 
  5. import java.io.FileReader; 
  6. import java.io.IOException; 
  7.  
  8. public class CPUUsage 
  9.     private static final String procPath = File.separator + "proc" + File.separator + "stat"
  10.  
  11.     public static void main(String[] args) 
  12.     { 
  13.         CPUTime startTime = new CPUTime(); 
  14.         CPUTime endTime = new CPUTime(); 
  15.  
  16.         getcpuTime(startTime); 
  17.         try 
  18.         { 
  19.             Thread.sleep(1000); 
  20.         } 
  21.         catch (InterruptedException e) 
  22.         { 
  23.             e.printStackTrace(); 
  24.         } 
  25.         getcpuTime(endTime); 
  26.  
  27.         double cpuUsage = 0
  28.         long totalTime = endTime.getTotalTime() - startTime.getTotalTime(); 
  29.         if (totalTime == 0
  30.         { 
  31.             cpuUsage = 0
  32.         } 
  33.         else 
  34.         { 
  35.             cpuUsage = 1 - (((double) (endTime.getIdleTime() - startTime.getIdleTime())) / totalTime); 
  36.         } 
  37.  
  38.         System.out.println("the cpu usage is: " + cpuUsage * 100 + "%"); 
  39.     } 
  40.  
  41.     private static void getcpuTime(CPUTime t) 
  42.     { 
  43.         BufferedReader fr = null
  44.         try 
  45.         { 
  46.             fr = new BufferedReader(new FileReader(new File(procPath))); 
  47.  
  48.             String oneLine = null
  49.             while ((oneLine = fr.readLine()) != null
  50.             { 
  51.                 if (oneLine.startsWith("cpu ")) 
  52.                 { 
  53.                     String[] vals = oneLine.substring(4).split(" "); 
  54.                     if (vals.length != 10
  55.                     { 
  56.                         System.err.println("read an error line string!"); 
  57.                     } 
  58.                     else 
  59.                     { 
  60.                         t.setTotalTime(Long.parseLong(vals[1]) + Long.parseLong(vals[2]) + Long.parseLong(vals[3]) 
  61.                                 + Long.parseLong(vals[4]) + Long.parseLong(vals[5]) + Long.parseLong(vals[6]) 
  62.                                 + Long.parseLong(vals[7]) + Long.parseLong(vals[8]) + Long.parseLong(vals[9])); 
  63.                         t.setIdleTime(Long.parseLong(vals[4])); 
  64.                         break
  65.                     } 
  66.                 } 
  67.             } 
  68.         } 
  69.         catch (NumberFormatException e) 
  70.         { 
  71.             e.printStackTrace(); 
  72.         } 
  73.         catch (IOException e) 
  74.         { 
  75.             e.printStackTrace(); 
  76.         } 
  77.         finally 
  78.         { 
  79.             if (fr != null
  80.             { 
  81.                 try 
  82.                 { 
  83.                     fr.close(); 
  84.                 } 
  85.                 catch (IOException e) 
  86.                 { 
  87.                     e.printStackTrace(); 
  88.                 } 
  89.             } 
  90.         } 
  91.     } 

CPUTime.java

  1. package com; 
  2.  
  3. public class CPUTime 
  4.     private long totalTime; 
  5.     private long idleTime; 
  6.  
  7.     public CPUTime() 
  8.     { 
  9.         totalTime = 0
  10.         idleTime = 0
  11.     } 
  12.  
  13.     public long getTotalTime() 
  14.     { 
  15.         return totalTime; 
  16.     } 
  17.  
  18.     public void setTotalTime(long totalTime) 
  19.     { 
  20.         this.totalTime = totalTime; 
  21.     } 
  22.  
  23.     public long getIdleTime() 
  24.     { 
  25.         return idleTime; 
  26.     } 
  27.  
  28.     public void setIdleTime(long idleTime) 
  29.     { 
  30.         this.idleTime = idleTime; 
  31.     } 

原文鏈接:http://shentar.me/%E9%80%9A%E8%BF%87procstat%E6%96%87%E4%BB%B

責任編輯:陳四芳 來源: shentar.me
相關推薦

2010-03-11 17:25:17

Linux系統使用率proc文件系統

2022-07-23 21:31:24

KubernetesLinux開源

2024-04-11 13:27:19

Linuxtop命令

2009-11-16 17:03:20

Oracle優化CPU

2019-01-15 15:04:54

CPU電腦使用率

2010-02-04 10:52:54

CentOS CPU

2021-08-10 11:45:57

topCPULinux

2021-05-31 15:53:57

CPU Top命令

2021-11-11 16:46:02

CPU使用率 .NET

2014-12-01 13:44:03

cgroupscpulimitlinux

2010-01-18 10:13:08

VB.NET獲取CPU

2023-03-06 08:41:32

CPU使用率排查

2009-12-15 15:12:05

Linux限制進程cp

2010-04-27 10:32:54

Oracle優化CPU

2021-09-16 10:21:58

topic容器容器信息

2019-09-24 14:52:35

CPU負載Linux

2012-07-03 09:57:11

閏秒Linux 服務器

2020-07-08 07:00:00

LinuxCPU應用程序

2009-12-22 09:23:59

Linux Sysst

2012-07-02 16:38:22

Linux服務器閏秒
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线婷婷 | 毛片视频免费观看 | 在线成人免费av | 国产精品久久久久久久久免费高清 | 国产日韩久久 | 亚洲一区在线播放 | 亚洲精品福利在线 | 国产精品综合色区在线观看 | 精品精品视频 | 久久精品一区 | 精品免费国产一区二区三区四区 | 日本成人福利视频 | 久久国际精品 | 精品99爱视频在线观看 | 日韩一区二区三区在线观看 | 亚洲精品68久久久一区 | 凹凸日日摸日日碰夜夜 | 精品在线| 亚洲精选一区二区 | 精品一区二区三区在线观看 | 午夜天堂精品久久久久 | a级大片免费观看 | 毛片99| 日韩精品成人一区二区三区视频 | 国产一区二区三区四区在线观看 | 99在线免费观看视频 | 日韩在线一区二区三区 | 中文在线一区二区 | 国产99视频精品免费视频7 | 97久久精品午夜一区二区 | 日韩午夜在线播放 | 色永久| 自拍 亚洲 欧美 老师 丝袜 | 美女黄网 | 国产一级片一区二区 | 国产成人综合在线 | 久在线| 黄色免费av | 国产精品福利在线 | 国产亚洲欧美在线 | 久久久久久成人 |