修改linux系统history命令的条数和格式

原生的history命令,只能看到输入的命令历史,看不到什么时候,谁输入的。

特此在网上找到修改history命令的办法:

1.用root用户打开系统环境变量设置的文件

vim /etc/profile

2.在最下面,插入下面几行代码

USER_IP=`who -u am i 2>/dev/null| awk '{print $NF}'|sed -e 's/[()]//g'`
export HISTTIMEFORMAT="%F %T  `whoami`  ${USER_IP}  "
export HISTSIZE=10000 #history 命令的记录数量
export HISTFILESIZE=10000 #记录文件的行数
export HISTIGNORE='ls*:ll' #忽略的命令
export PROMPT_COMMAND='if [ "$(history 1)" != "$(tail -n 1 /var/log/.myhistory 2>/dev/null)" ]; then history 1 >> /var/log/.myhistory; fi' #将命令记录输出到文本中

3.让环境变量生效

source /etc/profile

4.创建日志文件并赋予其他用户读写权限

touch /var/log/.myhistory
chmod 666 /var/log/.myhistory

以后再输入history命令,就会变成下面的样子了,有时间,有用户,有ip,而且保存最近1万条记录。

哼哼,再也不怕背锅了

这里解释下,为什么我要将命令单独记录到一个文件中,而不是直接用history命令查看呢?

因为history命令只能看到本用户下输入的命令,所以其实那个who am i没什么用。ip显示的也是当前用户登录的ip,你换个机器,history命令里记录的ip也会变,所以ip的历史也是假的。

所以需要将历史记录输出到文本中,这种方式改完后,/var/log/.myhistory文件中才是真正意义上的所有用户命令历史。

posted @ 2019-11-02 16:42  dijia478  阅读(995)  评论(0编辑  收藏  举报