linux系统history记录不全的原因

参考:

https://blog.csdn.net/imliuqun123/article/details/82978379

linux默认配置是当打开一个shell终端后,执行的所有命令均不会写入到~/.bash_history文件中,只有当前用户退出后才会写入,这期间发生的所有命令其它终端是感知不到的。

问题场景

那么问题来了,假若之前history命令记录为c0,用户先打开了shell终端a,执行了一部分命令c1,又打开了一个shell终端b,又执行了一部分命令c2.

问题1.终端a执行的这部分命令终端b上看不到。

问题2.终端a正常退出,相关命令会写入到~/.bash_history文件中(c1命令也会写入,即c0+c1),等到终端b正常退出后,相关命令也会写入到~/.bash_history文件中,注意这个时候终端b写入的内容为c0+c2,也即c1记录会丢失!!!

解决方案

将下面这段内容添加到~/.bashrc 并执行 . ~/.bashrc即可

  1. # format history

  2. # save in ~/.bashrc

  3. USER_IP=`who -u am i 2>/dev/null| awk '{print $NF}'|sed -e 's/[()]//g'`

  4. export HISTTIMEFORMAT="%Y-%m-%d %H:%M:%S `whoami`@${USER_IP}: "

  5. export HISTFILESIZE=1000000

  6. export PROMPT_COMMAND="history -a; history -r; $PROMPT_COMMAND"

  7. shopt -s histappend

  8. #bind '"\e[A": history-search-backward'

  9. #bind '"\e[B": history-search-forward'

第一行是获取USER_IP也就是会话的ip

第二行是设置history的时间格式,这里设置的格式为:history序号 2018-09-29 19:33:59 root@192.168.25.1: history

第三行设置的是history可以存放的历史命令最多可以存放1000000行

第四行 history -a 追加本次会话新执行的命令到.bash_history中也就是内存中的命令写入到历史文件中,history -r 读取历史文件中的所有历史命令到内存中的历史列表,即使内存中的列表中已经存在这条历史

第五行 打开histappend选项,将其修改为on 意为,推出这个回话后,回想shell中发送一个sighup的信号,告诉他我退出了