百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

如何在 Linux 中有效使用 history 命令?

liuian 2025-05-23 18:31 19 浏览

在 Linux 中,每当你在终端输入一条命令并按下回车,这条命令就会被默默记录下来。而 history 命令的作用,就是让你回顾这些操作的足迹。简单来说,它是一个“命令行日记本”,默认存储在用户主目录下的 .bash_history 文件中(针对 Bash shell 而言,其他 shell 可能略有不同,比如 Zsh 用 .zsh_history)。

敲下 history,你会看到类似这样的输出:

左侧是编号,右侧是命令本身。默认情况下,Bash 会记录最近 1000 条命令(具体数量取决于环境变量配置,后文会细说)。但 history 远不止“列个清单”这么简单——它能帮你节省时间、找回灵感,甚至避免重复劳动。

基础用法

1. 查看历史记录

最简单的方式,直接输入:

history 

这会列出所有记录的命令。如果列表太长,翻页不方便怎么办?试试配合管道:

history | less 

q 退出,或者用上下键浏览。

2. 只看最近几条

想快速瞥一眼最近的操作?加个数字:

history 5 

这会显示最近 5 条命令,比如:

3. 复用历史命令

敲了几百条命令后,突然想重复某个操作,比如第 42 号命令 sudo apt install nginx。别手动重打,直接:

!42 

终端会立刻执行这条命令。或者用感叹号加命令开头模糊匹配:

!sudo 

这会执行最近一次以 sudo 开头的命令,比如 sudo apt update

4. 上一个命令的快捷复用

忘了编号?没关系,!! 是你的救星。它直接调用上一条命令:

ls !! 

相当于又运行了一次 ls

5. 搜索历史命令

敲了几千条命令,找起来像大海捞针?用 Ctrl + R 进入交互式搜索模式:

  1. Ctrl + R
  2. 输入关键词,比如 git
  3. 终端会显示最近匹配的命令,比如 git pull origin main
  4. 继续按 Ctrl + R 翻找更早的匹配项,或者按回车直接执行。

进阶技巧:让 history 更聪明

1. 自定义时间戳

默认的 history 只显示编号和命令,想知道每条命令是什么时候执行的?编辑 ~/.bashrc 文件,加入:

export HISTTIMEFORMAT="%F %T " 

保存后,运行 source ~/.bashrc 生效。再敲 history,输出会变成:

这对排查问题或回顾操作时间超有用。

2. 调整历史记录大小

默认 1000 条不够用?或者嫌占空间?调整 HISTSIZEHISTFILESIZE

  • HISTSIZE:内存中保存的历史命令数量。
  • HISTFILESIZE.bash_history 文件中保存的最大条数。

编辑 ~/.bashrc,添加:

export HISTSIZE=5000 export HISTFILESIZE=10000 

重新加载配置后,历史容量就升级了。

3. 忽略重复或无用命令

每次敲 lscd 都记录下来,历史列表很快就被垃圾命令塞满。试试 HISTIGNORE

export HISTIGNORE="ls:cd:exit:pwd" 

加到 ~/.bashrc,以后这些命令就不会被记录。想忽略所有以空格开头的命令(比如敏感操作)?再加:

export HISTCONTROL=ignorespace 

输入时加个空格,比如 secret-tool,就不会留痕。

4. 实时保存历史

默认情况下,命令历史只有在退出终端时才写入 .bash_history,如果系统崩溃,之前的记录就没了。改用实时保存:

export PROMPT_COMMAND="history -a" 

加到 ~/.bashrc,每敲一条命令都会立刻写入文件。

5. 清空或删除特定记录

想清空所有历史?

history -c 

只删某一条,比如第 42 号命令?

history -d 42 

删除后,编号会自动调整。


高级玩法:让 history 成为生产力神器

1. 配合 grep 精准搜索

历史记录太多,Ctrl + R 不够快?用 history | grep

history | grep "nginx" 

找出所有包含 nginx 的命令,比如:

  123  sudo apt install nginx   456  nginx -t 

2. 执行历史命令的某部分

假设第 100 号命令是 scp file.txt user@remote:/tmp,你只想复用参数 user@remote:/tmp

!100:p 

这会打印而不执行,让你检查。确认后:

scp newfile.txt !100:$ 

$ 表示取最后一部分参数,结果是 scp newfile.txt user@remote:/tmp

3. 批量执行历史命令

想重复最近 3 条命令?用循环:

for i in {998..1000}; do !"$i"; done 

这会依次执行第 998 到 1000 号命令。

4. 跨终端共享历史

多个终端同时开着,但历史不互通?试试这个:

export PROMPT_COMMAND="history -a; history -n" 
  • history -a:追加当前终端历史到文件。
  • history -n:读取文件中的新记录到当前终端。

加到 ~/.bashrc,所有终端的历史就实时同步了。

5. 备份与恢复

担心 .bash_history 丢失?定期备份:

cp ~/.bash_history ~/history_backup_$(date +%F) 

恢复时:

cat ~/history_backup_2025-03-09 >> ~/.bash_history 

难杂症

1. 为什么有些命令没记录?

可能是 HISTCONTROL 设置了 ignoredups(忽略重复)或 ignorespace(忽略空格开头)。检查:

echo $HISTCONTROL 

调整或注释掉相关配置。

2. root 和普通用户的历史分开吗?

是的,root 的历史在 /root/.bash_history,普通用户在 ~/.bash_history。切换用户时,历史不会混淆。

3. 多 shell 兼容性

本文以 Bash 为主,但 Zsh、Fish 等 shell 也有类似功能。比如 Zsh 的 historyfc -l,用法稍有不同,具体可查文档。

4. 安全性提醒

历史记录可能包含密码或敏感命令(比如 mysql -u root -p123456)。养成加空格的习惯(配合 ignorespace),或者定期清理。

相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...