Linux下history命令的介绍

Linux下history命令的介绍

一、用处

对于Linux而言,命令是人机交互的重要方式,而查看命令历史可以帮助我们了解系统的使用状态、增强安全性也可以调用历史达到快捷操作的目的。

二、命令行历史

  执行过的命令会被存入缓存,当正常退出shell时,缓存中的命令会被写入文件中并保存在用户下的隐藏文件文件.bash_history中。当用户登陆时内存会在文件中读取命令历史再次存入缓存。


三、命令历史的调用


  重复执行上一条命令有四种方法:

    重复前一个命令使用上方向键,并回车执行;

    按 !! 并回车执行;

    输入 !-1 并回车执行;

    按 Ctrl+p 并回车执行。

  几个实用操作:

    !字符串:重复前一个以“字符串”开头的命令:

 blob.png


    !num:按照history命令输出中的序号重复对应命令:

 blob.png


    !?字符串:重复前一个包含该字符串的命令:

 blob.png

    !-n :重复n个命令之前的那个命令:

 blob.png


  在命令提示符中,使用↑(向上)和↓(向下)键来上下浏览从前输入的命令。

  键入ctrl+r来在命令历史中搜索命令

 blob.png

四、历史参数的调用

    #cmd !^ : 利用上一个命令的第一个参数做cmd的参数

    #cmd !$ : 利用上一个命令的最后一个参数做cmd的参数    

      也可以使用:Esc, .(点击Esc键后松开,然后点击 . 键)或 Alt+ .(按住Alt键的同时点击 . 键)       #cmd !* : 利用上一个命令的全部参数做cmd的参数

    #cmd !:n : 利用上一个命令的第n个参数做cmd的参数

    !n:^ 调用第n条命令的第一个参数

    !n:$ 调用第n条命令的最后一个参数

    !m:n 调用第m条命令的第n个参数

    !n:* 调用第n条命令的所有参数

    !string:^ 从命令历史中搜索以string 开头的命令,并获取它的第一个参数

    !string:$ 从命令历史中搜索以 string 开头的命令,并获取它
的最后一个参数

    !string:n 从命令历史中搜索以 string 开头的命令,并获取
它的第n个参数

    !string:* 从命令历史中搜索以 string 开头的命令,并获取
它的所有参数

五、history命令

  Linux下history是一个内部命令,主要用于显示缓存中历史指令记录内容, 或下达历史纪录中的指令。

  一些常用命令:

    -c:用于清空缓存中的命令历史

blob.png

     -d:删除历史中指定的命令;

blob.png

     #: 显示最近的#条历史;

blob.png

     -a: 把本次会话中新执行的命令历史列表从缓存追加至历史文件~/.bash_history中;

     -n: 显示历史文件~/.bash_history中未读过的行到历史列表,例如多个终端登录同一个用户时,缓存中的命令不会同步,使-n选项可以同步个终端的命令到历史列表中。

     -r: 把历史文件~/.bash_history中的命令附加到内存的历史列表中,每次打开shell都会默认执行类似操作;

     -w: 保存历史列表到指定的历史文件;

blob.png

     -p: 展开历史参数成多个行,但不存在历史列表中

blob.png

     -s: 展开历史参数成一行,附加在历史列表后(可以用来伪造命令)

blob.png

六、命令历史的相关环境变量

    HISTSIZE:定义内存中缓存命令条数的最大值;

blob.png


    HISTFILE:指定历史文件,默认为~/.bash_history;

blob.png


    HISTFILESIZE:命令历史文件记录历史的条数,用法与HISTSIZE相同;


    HISTTIMEFORMAT=“%F %T“ 显示时间:

blob.png


    HISTIGNORE="str1:str2: "忽略带有string1,string…”字符的历史命令。


    HISTCONTROL: 控制命令历史的记录方式


    ignoredups:忽略命令历史中已有的命令,且只记录第一条命令的时间


    ignorespace:忽略所有以空白行开头的命令


    ignoreboth:相当于ignoredups,ignorespace组合效果 


    erasedups:删除已有的重复命令

原创文章,作者:zhanghuanyu,如若转载,请注明出处:http://www.178linux.com/26143

(0)
zhanghuanyuzhanghuanyu
上一篇 2016-07-29 09:38
下一篇 2016-07-29 09:56

相关推荐

  • 8.5文本处理工具

    取本机ip地址 利用head命令取行首两行,tail命令取行尾一行, ifconfig |head -2 |tail -1   利用tr -s命令替换空格为“:”,并合并重复的“:”。利用cut -d:-f3命令,保留以“:”为分割符的第三部分   ifconfig |head -2 |tail -1 |tr -s "…

    Linux干货 2016-08-08
  • Shell脚本-循环基础

    Shell脚本-循环基础 背景: 正在学习Shell脚本之循环,发现Shell的循环和其他编程语言大同小异,逻辑上都是相通的,但在使用格式上却有点不同,在学习完Shell循环后,将学习的心得体会记录下来,以备今后复习。 介绍: 什么是Shell脚本:       shell script是利用shell的功能…

    2017-08-26
  • 推荐-HA专题: 编译安装并配置DRBD

    HA专题: 编译安装并配置DRBD 前言 实验环境 DRBD介绍 安装前准备工作 获取并编译安装DRBD 配置DRBD 分区 配置文件 启动并设置DRBD 格式化并挂载 验证冗余性 总结 前言 上篇我们讲到使用corosync+pacemaker实现MySQL高可用, 但是NFS容易成为单点故障从而导致数据丢失等严重问题, 我们可以使用drbd来实现MySQ…

    Linux干货 2016-04-12
  • redis主/从配置及基于sentinel的故障转移

    一、NoSQL基础概念: ACID:原子性、一致性、隔离性、持久性;特性:数据量大、数据变化非常大(数据增长化、流量分布变化、数据间耦合结构变化)、数据源很多; CAP、BASECAP C:多个数据节点的的数据一致;A:用户发出请求后的有限时间范围内返回结果;P:network partition,网络发生分区后,服务是否依可用;CAP理论:一个分布式系统不…

    Linux干货 2017-01-27
  • iptables总结

    iptables简称为包过滤型防火墙一般分为2种:     1,主机防火墙:主机防火墙是用来防止本主机内的应用服务被攻击所需要保护的防火墙     2,网络防火墙:做为想路由功能的防火墙凡是进过此服务器的数据包都要进行规则匹配 iptables的架构由功能和链组成  &…

    Linux干货 2016-12-05
  • N25_第四周作业(补)

    1、复制/etc/skel目录到/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@EASTED tmp]# cp -r /etc/skel/ /home/tuser1/ [root@EASTED tmp]# cp …

    Linux干货 2017-01-02

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-29 09:49

    写的很好,但是字体能统一一下会更好!!!