成人免费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間隔足夠小(小于10ms),則可能出現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
相關推薦

2022-07-23 21:31:24

KubernetesLinux開源

2010-03-11 17:25:17

Linux系統使用率proc文件系統

2009-11-16 17:03:20

Oracle優化CPU

2024-04-11 13:27:19

Linuxtop命令

2019-01-15 15:04:54

CPU電腦使用率

2010-02-04 10:52:54

CentOS CPU

2021-05-31 15:53:57

CPU Top命令

2021-08-10 11:45:57

topCPULinux

2021-11-11 16:46:02

CPU使用率 .NET

2010-04-27 10:32:54

Oracle優化CPU

2014-12-01 13:44:03

cgroupscpulimitlinux

2021-09-16 10:21:58

topic容器容器信息

2010-01-18 10:13:08

VB.NET獲取CPU

2009-12-15 15:12:05

Linux限制進程cp

2023-03-06 08:41:32

CPU使用率排查

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服務器閏秒

2022-09-15 08:01:32

CPU使用率異步
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品伦一区二区三级视频 | 欧美精品导航 | 中文精品视频 | 国产精品人人做人人爽 | 91国产在线视频在线 | jdav视频在线观看免费 | 男人的天堂一级片 | 国产欧美精品一区二区色综合 | 狠狠操婷婷 | 在线免费观看亚洲 | 国产精品久久久久aaaa | 一区二区三区视频在线观看 | 日韩国产欧美一区 | 午夜黄色| 中文字幕一区在线观看视频 | 亚洲国产成人精品久久 | 国产成人精品网站 | 亚洲精品乱码久久久久久蜜桃91 | 欧美一级www片免费观看 | 午夜影院在线免费观看视频 | 日韩欧美在线播放 | 欧美综合在线观看 | 欧美性久久 | 啪啪综合网 | 国产精品一区久久久久 | 欧美日韩一区二区电影 | 欧美精品一区三区 | 久久精品小视频 | 国产精品精品视频一区二区三区 | 国产精品99精品久久免费 | 我想看一级黄色毛片 | 狠狠伊人| 国产精品久久网 | 成人欧美一区二区三区在线观看 | 婷婷激情在线 | www.久草.com | 少妇一级淫片免费播放 | 日本久久久影视 | 日韩在线一区二区三区 | 亚洲成人福利 | 亚洲视频一区在线观看 |