詳解Linux命令history查看執行時間

Linux命令行中使用history命令可以查看之前執行的命令記錄,但是,通過history命令也可以查看每個命令執行的時間,方便我們分析、查找和優化命令執行情況。本文將從多個方面對history命令查看命令執行時間做詳細闡述。

一、history查看命令執行時間基本用法

history命令可以顯示之前執行的命令列表,並且其中包含了執行時間信息,history命令的基本使用方法如下:

$ history
...
 2465  2022-02-15 17:13:34 ls
 2466  2022-02-15 17:13:43 date
 2467  2022-02-15 17:13:49 pwd
 2468  2022-02-15 17:13:54 whoami
...

上面的歷史命令顯示了之前執行過的一些命令,包括執行時間、命令數字和命令本身。從輸出結果可以看出,每一個命令的前面都有一個數字,該數字即為這個命令的唯一標識(也稱為歷史命令號)。同時,每條命令的前面都有一個時間戳,該時間戳包含了該命令的執行日期和時間。

二、使用history命令查看命令執行的時間範圍

有時候,我們需要僅查看一段時間內執行的命令,我們可以通過history命令的選項來實現。history命令的選項-r和-t可以幫助我們檢索特定時間範圍內的歷史記錄。

# 下面的命令會顯示過去24小時內執行的所有命令
$ history -t $(date +%s -d '24 hours ago') 

# 下面的命令會顯示從2022年1月1日到現在的所有命令
$ history -r '2022-01-01'

其中,選項-t接受一個時間戳作為參數,該時間戳是Unix時間(即自1970年1月1日0時0分0秒UTC起的秒數),通過date命令獲取24小時前的時間戳,實現了查看過去24小時內執行的所有命令。

選項-r需要指定一個日期和時間的範圍,通過此選項我們可以查看特定時間範圍內執行的所有命令。上述命令通過-r選項,指定了從2022年1月1日開始的命令執行記錄。

三、使用history命令查看具體的命令執行時間和執行時間間隔

除了上述的兩種基本使用方法,通過history命令還可以查看具體的命令執行時間和執行時間間隔。具體方法如下:

# 顯示最新執行命令的時間信息
$ history 1

# 顯示命令號為2465的命令的執行時間信息
$ history 2465

# 顯示命令號為2465和2466的命令的執行時間間隔
$ history 2465 2466

上述命令中,history命令通過指定參數,實現了查看具體的命令執行時間和執行時間間隔。

四、結合grep命令查找特定命令的執行時間

有時候我們需要查找某個命令的執行時間,可以使用grep命令結合history命令來實現。grep命令可以按照用戶指定的模式,在文件或標準輸入流中搜索匹配的行,並返回匹配的結果。

# 顯示包含字符串「ls」的命令的執行時間信息
$ history | grep 'ls'

# 顯示包含字符串「-a」和「-l」且以「chmod」命令開頭的命令的執行時間信息
$ history | grep '^chmod.*-a.*-l'

上述命令中,history命令輸出了之前執行的所有命令,然後通過管道符(|)將輸出結果傳遞給grep命令進行過濾。grep命令通過指定搜索模式,篩選出包含指定字符串的命令,並返回相關執行時間信息。

五、使用bash內置變量獲取命令執行時間信息

在bash中,還可以通過一些內置變量來獲取命令執行的時間信息,比如$SECONDS和$LINENO。

其中,$SECONDS變量表示腳本或命令行shell的運行時間,單位為秒。$LINENO表示正在執行的當前腳本或命令行shell中的命令的行號。

$ echo "該命令執行了 $SECONDS 秒"

$ echo "當前命令所在行號:$LINENO"

上述命令將打印出腳本或命令行shell的運行時長和當前命令所在的行號。

六、結合其他命令查看命令執行時間信息

除了上述命令外,還可以通過其他命令結合history命令來查看命令執行時間信息。比如,我們可以結合awk命令,篩選出歷史命令中最早和最晚的時間戳,以及整個命令執行的時間間隔。

# 顯示歷史列表中最早和最晚的時間戳,以及命令執行的時間間隔
$ history | awk '{print $2}' | {head -n1 && tail -n1; printf "%.2f minutes total.\n",($NF-$2)/60}'

# 顯示歷史列表中最早和最晚的時間戳,以及命令執行的時間間隔(以小時為單位)
$ history | awk '{print $2}' | {head -n1 && tail -n1; printf "%.2f hours total.\n",($NF-$2)/3600}'

上述命令分別通過head命令和tail命令,獲取歷史命令列表中最早和最晚的時間戳。隨後,使用awk命令進行解析,計算出命令執行的時間間隔,並按照分鐘或小時為單位輸出。

總結

通過本文的介紹,相信大家已經掌握了Linux命令history查看命令執行時間的各種方法。通過結合不同的命令,我們可以更加靈活方便地查看和分析命令執行時間信息,提高我們的工作效率。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/291551.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-24 14:16
下一篇 2024-12-25 14:06

相關推薦

  • Git config命令用法介紹:用正確的郵箱保障開發工作

    本文將詳細介紹如何使用git config命令配置Git的全局和本地用戶信息,特別是如何正確使用用戶郵箱,保障Git操作的正常進行。 一、git config命令介紹 Git中的每…

    編程 2025-04-29
  • Python命令大全及說明

    Python是一種高級編程語言,由Guido van Rossum於1989年底發明。它具有良好的語法結構和面向對象的編程思想,具有簡潔、易讀、易學的特點,是初學者以及專業開發人員…

    編程 2025-04-29
  • Python SSH 遠程執行命令

    Python SSH 遠程執行命令是指在一個服務器上執行遠程另一個服務器上命令。如果你需要在本地機器上執行命令,或者在遠程機器上執行本地命令,你都可以使用 SSH。在 Python…

    編程 2025-04-29
  • 剖析命令執行函數

    在編程開發過程中,命令執行函數是非常常見的一個概念。它是指接受一個命令字符串,並將其解析執行,返回相應的結果或錯誤信息的函數。本文將從多個方面對命令執行函數進行詳細的闡述,包括其定…

    編程 2025-04-28
  • 如何使用Python執行Shell命令並獲取執行過程信息

    本文將介紹如何使用Python執行Shell命令並獲取執行過程信息。我們將從以下幾個方面進行闡述: 一、執行Shell命令 Python內置的subprocess模塊可以方便地執行…

    編程 2025-04-28
  • Python中獲取用戶輸入命令的方法解析

    本文將從多個角度,分別介紹Python中獲取用戶輸入命令的方法,希望能夠對初學者有所幫助。 一、使用input()函數獲取用戶輸入命令 input()是Python中用於獲取用戶輸…

    編程 2025-04-27
  • Python3 執行 cmd 命令用法介紹

    本文將詳細講解如何使用Python3執行cmd命令,包括使用subprocess模塊、os模塊、Popen方法、system方法等多個方面的實現方法。 一、使用subprocess…

    編程 2025-04-27
  • 全面解析Python直接命令更新

    本文將從多個方面對Python直接命令更新進行詳細闡述,包括更新命令的基本用法、更新過程中可能遇到的問題及其解決方法等等。 一、更新命令基本用法 Python直接命令更新是一種非常…

    編程 2025-04-27
  • 如何在Linux中添加用戶並修改配置文件

    本文將從多個方面詳細介紹在Linux系統下如何添加新用戶並修改配置文件 一、添加新用戶 在Linux系統下創建新用戶非常簡單,只需使用adduser命令即可。使用以下命令添加新用戶…

    編程 2025-04-27
  • Python啟動命令用法介紹

    Python是一門解釋型語言,與許多編譯型語言不同,它不需要編譯成機器碼,而是通過解釋器一行一行讀取程序,逐句翻譯成目標代碼然後運行。因此,對於Python程序員來說,學會如何正確…

    編程 2025-04-27

發表回復

登錄後才能評論