Linux環境下查看歷史操作命令及清除方法(history -c)


在Linux環境中可以通過方向鍵的上下按鍵查看近期鍵入的命令。但這種方法只能一個一個的查看,其實系統提供了查看所有歷史命令的方法。

在終端中輸入以下命令查看所有命令:

history

復制代碼
[root@template ~]# history
    1  ifconfig
    2  vim /etc/ssh/sshd_config 
    3  /etc/init.d/sshd restart
    4  vim /boot/grub/grub.conf 
    5  vim /etc/selinux/config 
    6  vim /etc/sysconfig/network-scripts/ifcfg-eth0
    7  rm -rf /etc/udev/rules.d/70-persistent-net.rules 
    8  useradd vsroot
    9  echo -e 'vsroot\tALL=(ALL)\tNOPASSWD: ALL' >> /etc/sudoers
   10  yum clean all
   11  rm -rf /var/log/yum.log 
   12  rm -rf /var/lib/yum/*
   13  rm -rf /root/install.log
   14  rm -rf /root/install.log.syslog 
   15  rm -rf /var/log/anaconda.*
復制代碼

 

history命令列出了所有已鍵入的命令,用戶所鍵入的命令都會記錄在文件中,該文件保存在當前登錄用戶的家目錄中。

文件名稱為:.bash_history,該文件是一個隱藏文件。

 

歷史操作命令的清除:

如果在服務器中干了不好的事情,可以通過“history -c”命令進行清除,那么其他人登錄終端時就無法查看歷史操作命令了。

但此命令並不會清除保存在文件中的記錄,因此需要手動刪除.bash_profile文件中的記錄。

 

配置是否記錄歷史操作命令或記錄條數:

在“/etc/profile”配置文件中可以配置是否記錄歷史操作命令。

vi /etc/profile

復制代碼
[root@CentOS ~]# cat /etc/profile
# /etc/profile

# System wide environment and startup programs, for login setup
# Functions and aliases go in /etc/bashrc

# It's NOT a good idea to change this file unless you know what you
# are doing. It's much better to create a custom.sh shell script in
# /etc/profile.d/ to make custom changes to your environment, as this
# will prevent the need for merging in future updates.

pathmunge () {
    case ":${PATH}:" in
        *:"$1":*)
            ;;
        *)
            if [ "$2" = "after" ] ; then
                PATH=$PATH:$1
            else
                PATH=$1:$PATH
            fi
    esac
}


if [ -x /usr/bin/id ]; then
    if [ -z "$EUID" ]; then
        # ksh workaround
        EUID=`id -u`
        UID=`id -ru`
    fi
    USER="`id -un`"
    LOGNAME=$USER
    MAIL="/var/spool/mail/$USER"
fi

# Path manipulation
if [ "$EUID" = "0" ]; then
    pathmunge /sbin
    pathmunge /usr/sbin
    pathmunge /usr/local/sbin
else
    pathmunge /usr/local/sbin after
    pathmunge /usr/sbin after
    pathmunge /sbin after
fi

HOSTNAME=`/bin/hostname 2>/dev/null`
HISTSIZE=1000
if [ "$HISTCONTROL" = "ignorespace" ] ; then
    export HISTCONTROL=ignoreboth
else
    export HISTCONTROL=ignoredups
fi

export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL

# By default, we want umask to get set. This sets it for login shell
# Current threshold for system reserved uid/gids is 200
# You could check uidgid reservation validity in
# /usr/share/doc/setup-*/uidgid file
if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
    umask 002
else
    umask 022
fi

for i in /etc/profile.d/*.sh ; do
    if [ -r "$i" ]; then
        if [ "${-#*i}" != "$-" ]; then
            . "$i"
        else
            . "$i" >/dev/null 2>&1
        fi
    fi
done

unset i
unset -f pathmunge
[root@CentOS ~]#
復制代碼

 

在profile配置文件中找到HISTSIZE選項,該配置選項用於配置歷史操作命令條數的。

如果將此值置0則不記錄歷史操作命令。

默認該值為1000,也就是記錄最近的1000條命令。

如果需要增大后縮小記錄的條數,則修改相應的值即可。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM