歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> 關於Linux

linux中的兩個time

linux中的兩個time     今天發現linux中還有兩個time指令,小結下:    www.2cto.com   在linux中存在兩個time,一個是bash的命令,另外一個是程序/usr/bin/time,bash的time命令只能很簡單的顯示程序執行的時間,而/usr/bin/time程序可以顯示很詳細的與IO相關的數據,比如從內存中讀取了多少數據,從磁盤中讀取了多少數據之類的,以及文件系統的頁大小。   www.2cto.com   通過type命令我們可以看到Linux中的兩個time  oracle@linux[]:~  $type -a time  time is a shell keyword  time is /usr/bin/time  bash中的time示例  oracle@linux[]:~  $time echo test  test    real    0m0.000s  user    0m0.000s  sys     0m0.000s  bash中的time命令只能顯示你程序的執行時間,包括實際執行時間,用戶時間和系統時間,除此之外沒有其他的信息。  而time程序就不一樣了,它可以提供很詳盡的信息,而且還能夠定制time程序的輸出結果,具體的可以通過man time查看,這裡僅僅列舉下time -v參數下的數據顯示。  oracle@linux[]:~  $/usr/bin/time -v echo test  test          Command being timed: "echo test"          User time (seconds): 0.00          System time (seconds): 0.00          Percent of CPU this job got: 0%          Elapsed (wall clock) time (h:mm:ss or m:ss): 0:00.01          Average shared text size (kbytes): 0          Average unshared data size (kbytes): 0          Average stack size (kbytes): 0          Average total size (kbytes): 0          Maximum resident set size (kbytes): 0          Average resident set size (kbytes): 0          Major (requiring I/O) page faults: 113          Minor (reclaiming a frame) page faults: 16          Voluntary context switches: 0          Involuntary context switches: 0          Swaps: 0          File system inputs: 0          File system outputs: 0          Socket messages sent: 0          Socket messages received: 0          Signals delivered: 0          Page size (bytes): 4096          Exit status: 0  從上面的輸出結果我們可以看到,除了CPU時間之外,通常我們還關心下面幾個:  Major (requiring I/O) page faults  從磁盤中讀取了多少頁的數據。  Minor (reclaiming a frame) page faults  從操作系統緩存中讀取了多少頁的數據。  Swaps  進程被swap出內存的次數。  File system inputs/outputs  從文件系統中讀取/寫入的數據數量。  Page size (bytes)  操作系統的頁大小。    --------------------------------------    關於time中的三態的補充講解:    核心態(Kernel Mode):    在內核態,代碼擁有完全的,不受任何限制的訪問底層硬件的能力。可以執行任意的CPU指令,訪問任意的內存地址。內核態通常情況下,都是為那些最底層的,由操作系統提供的,可信可靠的代碼來運行的。內核態的代碼崩潰將是災難性的,它會影響到整個系統。      用戶態(User Mode):    在用戶態,代碼不具備直接訪問硬件或者訪問內存的能力,而必須借助操作系統提供的可靠的,底層的APIs來訪問硬件或者內存。由於這種隔離帶來的保護作用,用戶態的代碼崩潰(Crash),系統是可以恢復的。我們大多數的代碼都是運行在用戶態的。      我們來看看這三個的關系,這三者之間沒有嚴格的關系,常見的誤區有:    誤區一: real_time = user_time + sys_time    我們錯誤的理解為,real time 就等於 user time + sys time,這是不對的,real time是時鐘走過的時間,user time 是程序在用戶態的cpu時間,sys time 為程序在核心態的cpu時間。    利用這三者,我們可以計算程序運行期間的cpu利用率如下:    %cpu_usage = (user_time + sys_time)/real_time * 100%    如:    # time sleep 2    real 0m2.003s    user 0m0.000s    sys 0m0.000s    cpu利用率為0,因為本身就是這樣的,sleep 了2秒,時鐘走過了2秒,但是cpu時間都為0,所以利用率為0    誤區二:real_time > user_time + sys_time    一般來說,上面是成立的,上面的情況在單cpu的情況下,往往都是對的。    但是在多核cpu情況下,而且代碼寫的確實很漂亮,能把多核cpu都利用起來,那麼這時候上面的關系就不成立了,例如可能出現下面的情況,請不要驚奇。    real 1m47.363s    user 2m41.318s    sys 0m4.013s    -------------------------
Copyright © Linux教程網 All Rights Reserved