Each command executed in your Linux terminal is taken as an event and associated with an event number (or index number) later found in the “~/.bash_history
” file.
Now, you can use a program like a “cat
” to read the record of this file, but Linux provides a separate “history
” command that gives you more features and functionality.
It involved features like viewing history records, removing single or complete records, executing a specific command from the history using its event number, and many more.
In this article, you will learn how to configure history records, history command usages, and a few more tips that will help you in your Linux journey.
Tutorial Details
Description | History |
Difficulty Level | Low |
Root or Sudo Privileges | No |
OS Compatibility | Ubuntu, Manjaro, Fedora, etc. |
Prerequisites | history |
Internet Required | No |
Syntax of the History Command
The history command takes only one argument for specifying the option (and it is optional).
$ history [OPTION]
View the History Record
Get to your terminal and execute the following command without any options to display the list of all executed commands in the past.
$ history
Output:
data:image/s3,"s3://crabby-images/bfe81/bfe81963856b738ca3fab223f4cf8f8924fef20c" alt="Viewing the history record"
Or, if you are interested in the five most recent history records, specify the number of records you wish to list in integer format using the history command.
$ history 5
Output:
data:image/s3,"s3://crabby-images/3b594/3b5944267c8627c5c82bb88111f22dbd12d63bf2" alt="Viewing the recent five history records"
Once you close the terminal, the records for the current session will be reflected in the history file.
Displaying Records with Date and Timestamps
Currently, the history command only shows the event number (or index number) along with the user-executed commands; however, you can also display the date and time along with these records.
For that, you need to configure your shell configuration file, like “~/.bashrc
” for Bash shell, using your choice of text editor, either Vim or Nano.
$ vim ~/.bashrc
Now, add the following record at the end of the configuration file.
export HISTTIMEFORMAT="%c "
Output:
data:image/s3,"s3://crabby-images/7cd10/7cd108338831a5b1d090a123c9351281e425cbb8" alt="Modifying the shell configuration file for the history command"
Save and close the file, and then reload the configuration file using the source command to reflect the changes.
$ source ~/.bashrc
Lastly, execute the history command to verify the changes.
$ history
Output:
data:image/s3,"s3://crabby-images/cbe5e/cbe5eb0cf9fa619aaa6ce0a888e549c3a547f8ff" alt="Displaying the date and timestamp with history records"
Configuring the History Command
The shell configuration file (“~/.bashrc
“) has two variables that control the history buffer.
HISTSIZE
: It’s responsible for showing the defined number of results when the history command is executed.HISTFILESIZE
: It’s responsible for recording a certain number of user executed commands in the history file.
data:image/s3,"s3://crabby-images/36bed/36bedfd31fc7ae864a0710de1999fe1f27a30d27" alt="History setting in the shell configuration file"
For example, if “HISTSIZE=1000
” is specified, then when you execute the history command, it will only list the 1000 records.
And if “HISTFILESIZE=2000
” is set, then only 2000 user-executed commands will be stored in the history file, and once it reaches the edge point, it will start removing and adding one record.
For example, if you want to only list ten results when the history command is executed, replace “HISTSIZE=1000
” with “HISTSIZE=10
“, as shown.
data:image/s3,"s3://crabby-images/1fa5b/1fa5bc1fd2af19d9c2fd07c529a30bb84fc2818f" alt="Modifying the "HISTSIZE" variable"
Save and close the file, restart the terminal session, and execute the history command to view the changes.
$ history
Output:
data:image/s3,"s3://crabby-images/91280/912809125b920eda8ea5776912aa9d0208698a52" alt="Showing the 10 entries in history"
Executing Command Using Event Number
Every executed command is stored with an event number in the history list, and this event number can be used to reuse the assigned command with the (“!
“) exclamation mark.
$ !298
Output:
data:image/s3,"s3://crabby-images/9918e/9918e12ac6204bb33cc080b69b453789e8368b3f" alt="Reusing the previously executed command"
Or, use the “:p
” after the event number to view the command before executing it, so the wrong command does not get executed.
$ !298:p
Output:
data:image/s3,"s3://crabby-images/3f46d/3f46da6d7fb2719c3d9d39429030da59b0a49e4c" alt="Viewing the record before executing"
Also, you can add a dash (“-
“) before the index number to start counting from the end of the list.
$ !-2
The above command will execute the second last command from the history list.
data:image/s3,"s3://crabby-images/d13c0/d13c0e3534d06b7c896df7d0eb35c4701a6f7678" alt="Executing the second last execute command"
Or, use the double exclamation mark (“!!
“) to repeat the last executed command.
$ !!
Output:
data:image/s3,"s3://crabby-images/ba456/ba4562829ae2087a5223c30e220afed22c718747" alt="Re-executing the last executed command"
I personally use the double exclamation mark when I forget to add “sudo
” in front of any command that requires it, for example, the “sudo apt update
” command.
$ sudo !!
Output:
data:image/s3,"s3://crabby-images/e179c/e179c9a187d79735ff0a3d95f2ccf2f4895913ea" alt="Adding sudo before the command using a double exclamation mark"
Searching for Command by String
Adding a string in front of the exclamation mark will execute the most recently executed command that starts with the specified string.
Recently, the “sudo apt update
” command was executed, so if “sudo
” is specified as a string with an exclamation mark, then it reruns the same command.
$ !sudo
Output:
data:image/s3,"s3://crabby-images/0609a/0609a983db59c6acd60091ce17f98e0f28369400" alt="Executing the latest recent command with the specified string"
Listing the Matching Commands
You can combine (pipe) the history command with the grep command to get the list of matching commands that contain the specified string.
For example, the following command will display a list of all commands that contain the “sudo” string.
$ history | grep sudo
Output:
data:image/s3,"s3://crabby-images/75072/75072b69fe827f1f89ed3333c4dd1017ef2b6559" alt="Displaying the list of commands with specific string"
Replacing the String from a Recently Executed Command
You can use the following syntax to replace the string from a recently executed command:
$ ^[OLD_STRING]^[NEW_STRING]^
For example, the last executed command in my system is “sudo apt update
“, and I want to replace “sudo
” with its minimalist variant “doas
” using the following command:
$ ^sudo^doas^
Output:
data:image/s3,"s3://crabby-images/a3c85/a3c85fcee949db388120eaf3337e23a2fb4f0134" alt="Replacing the string from the recently executed command"
Executing Command Without Recording in History
There are multiple ways to prevent an executed command from appearing in the history record; the most straightforward is using the set command, which will temporarily disable the command recording.
$ set +o history
Once you’re done with the command execution, you can re-enable it using the following command:
$ set -o history
Deleting the Single or Complete History Record
You can use the “-d
” flag with a specific event number (or index number) to remove a specific record from the history list.
$ history -d 299
The above command will remove the command with event number “299” from the history list.
data:image/s3,"s3://crabby-images/c60fe/c60fefb69c5cc39d8e4a259314970e1a06c0bea5" alt="Removing a specific command from the history list"
Or, you can use the “-c
” flag to wipe out the complete record from the history list.
$ history -c
Output:
data:image/s3,"s3://crabby-images/20820/20820ae358c75a2c28c81584038d11c7860ad56f" alt="Clearing the complete history record"
That was the last example of this command.
This article is enough for a beginner or professional to understand the concept of history and history records in Linux.
However, if something that needs to be added is not included, please mention it in the comment section.
Till then, sayonara!
Join The Conversation
Users are always welcome to leave comments about the articles, whether they are questions, comments, constructive criticism, old information, or notices of typos. Please keep in mind that all comments are moderated according to our comment policy.