Linux history使用[收藏]_打杂的_新浪博客

本文详细介绍了 Linux 系统中的 history 命令,包括其基本语法、常用参数及实战应用。通过 history 命令,用户可以高效地管理历史命令记录,提高工作流程效率。

如果你经常使用Linux命令,那么使用history命令无疑会提升你的工作效率。

History命令主要用于显示历史指令记录内容, 下达历史纪录中的指令 。

1>History命令语法: 

[test@linux]# history [n]

[test@linux]# history [-c]

[test@linux]# history [-raw] histfiles

参数:

n   :数字,要列出最近的 n 笔命令列表

-c  :将目前的shell中的所有 history 内容全部消除

-a  :将目前新增的history 指令新增入 histfiles 中,若没有加 histfiles ,

则预设写入 ~/.bash_history

-r  :将 histfiles 的内容读到目前这个 shell 的 history 记忆中

-w  :将目前的 history 记忆内容写入 histfiles

Linux系统当你在shell(控制台)中输入并执行命令时,shell会自动把你的命令记录到历史列表中,一般保存在用户目录下的.bash_history文件中。默认保存1000条,你也可以更改这个值。

如果你键入 history, history会向你显示你所使用的前1000个历史命令,并且给它们编了号,你会看到一个用数字编号的列表快速从屏幕上卷过。你可能不需要查看1000个命令中的所有项目, 当然你也可以加入数字来列出最近的 n 笔命令列表。

linux中history命令不仅仅让我们可以查询历史命令而已. 我们还可以利用相关的功能来帮我们执行命令。

2>运行特定的历史命令

history会列出bash保存的所有历史命令,并且给它们编了号,我们可以使用“叹号接编号”的方式运行特定的历史命令.

语法说明:

[test@linux]# [!number]  [!command] [!!]

参数说明:

number   :第几个指令的意思;

command  :指令的开头几个字母

!        :上一个指令的意思!

3>History命令实战

列出所有的历史记录:

[test@linux] # history

只列出最近10条记录:

[test@linux] # history 10 (注,history和10中间有空格)

使用命令记录号码执行命令,执行历史清单中的第99条命令

[test@linux] #!99 (!和99中间没有空格)

重复执行上一个命令

[test@linux] #!!

执行最后一次以rpm开头的命令(!?  ?代表的是字符串,这个String可以随便输,Shell会从最后一条历史命令向前搜索,最先匹配的一条命令将会得到执行。)

[test@linux] #!rpm

逐屏列出所有的历史记录:

[test@linux]# history | more

立即清空history当前所有历史命令的记录

[test@linux] #history -c

除了使用history命令,在 shell 或 GUI 终端提示下,你也可以使用上下方向键来翻阅命令历史(向下箭头会向前翻阅),直到你找到所需命令为止。这可以让我们很方便地编辑前面的某一条命令,而不用重复输入类似的命令。

History命令的用途确实很大!但需要小心安全的问题!尤其是 root 的历史纪录档案,这是黑客们的最爱!因为不小心的 root 会将很多的重要资料在执行的过程中会被纪录在 ~/.bash_history 当中,如果这个档案被解析的话,后果不堪设想!

本文来源于时光漂流瓶 http://www.9usb.net , 原文地址: http://www.9usb.net/200906/linux-history-mingling.html 

### HARDEN_BRANCH_PREDICTOR 和 HARDEN_BRANCH_HISTORY 的配置与使用Linux 内核中,`HARDEN_BRANCH_PREDICTOR` 和 `HARDEN_BRANCH_HISTORY` 是用于缓解**分支预测器攻击**(如 Spectre 变体)的安全强化选项。这些配置旨在通过限制用户空间对分支预测状态的可观察性,来防止恶意代码利用间接分支推测执行泄露敏感信息。 #### HARDEN_BRANCH_PREDICTOR `HARDEN_BRANCH_PREDICTOR` 是一种内核配置选项,启用后会在上下文切换时刷新**全局分支预测状态**。其目的是防止一个进程影响另一个进程的分支预测行为,从而降低跨进程边界的侧信道攻击风险。此机制通常适用于支持硬件隔离特性的 CPU,例如 Intel 的 Indirect Branch Restricted Speculation (IBRS) 或 AMD 的等效功能[^1]。 启用该配置后,内核会在调度任务时插入额外的屏障指令(如 `LFENCE` 或 `IBPB`),以确保前一个进程的间接分支预测状态不会影响后续进程。这种方式虽然增加了上下文切换的开销,但显著提升了安全性。 示例配置方式如下: ```makefile CONFIG_HARDEN_BRANCH_PREDICTOR=y ``` #### HARDEN_BRANCH_HISTORY `HARDEN_BRANCH_HISTORY` 是更进一步的安全强化机制,它不仅在上下文切换时刷新分支预测状态,还在系统调用、中断和异常处理期间进行刷新。这种增强措施是为了防止用户空间程序通过观测内核路径的间接分支行为来推测内核地址或访问模式[^1]。 此配置特别适用于高安全需求的环境,如多租户服务器或容器平台,其中用户空间可能运行不受信任的代码。尽管增强了安全性,但它也可能带来一定的性能开销,尤其是在频繁进行系统调用的应用场景中。 启用方式如下: ```makefile CONFIG_HARDEN_BRANCH_HISTORY=y ``` #### 使用建议与注意事项 - **依赖 CPU 架构**:这两个选项仅在支持相关硬件特性的处理器上生效。例如,Intel 处理器需要 IBRS/STIBP 支持,而 AMD 则依赖于类似机制。 - **性能影响**:启用 `HARDEN_BRANCH_HISTORY` 会增加系统调用和上下文切换的延迟,因此需根据实际应用场景权衡安全性和性能。 - **组合使用**:若同时启用 `HARDEN_BRANCH_PREDICTOR` 和 `HARDEN_BRANCH_HISTORY`,则后者的行为将覆盖前者,提供更全面的保护[^1]。 - **内核版本要求**:这些特性最早出现在 Linux 内核 4.9 之后的版本中,并随着安全更新不断完善。建议使用较新的稳定版内核以获得更好的兼容性与支持。 #### 示例:检查是否启用 可以通过以下命令查看当前内核配置是否启用了这些安全选项: ```bash grep CONFIG_HARDEN_BRANCH /boot/config-$(uname -r) ``` 输出可能包括: ```text CONFIG_HARDEN_BRANCH_PREDICTOR=y CONFIG_HARDEN_BRANCH_HISTORY=y ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值