历史命令与实时记录(redhat6.8)
歷史命令與實時記錄(redhat6.8)
linuxshell2018年02月13日 10時58分53秒
?
-
- 參數(shù)
- HISTTIMEFORMAT
- HISTSIZE
- HISTFILESIZE
- HISTFILE
- HISTCONTROL
- HISIGNORE
- 實時記錄參數(shù)(PROMPT_COMMAND)
- 實例腳本
- 參數(shù)
?
默認情況下,我們在命令行指定的命令,在我們退出當前用戶之后,內存中存儲的歷史命令會記錄到家目錄的.history文件中,日志的格式以及這種記錄的方法都是根據(jù)一系列的參數(shù)決定的,我們可以修改這些參數(shù),定制日志記錄。
參數(shù)
HISTTIMEFORMAT
決定歷史記錄的格式,是否加時間。
?
未指定樣式之前
?
?
修改默認樣式
?
我們?yōu)楸敬文_本定制一個更加直觀的樣式:
# 后面的%F %T是c函數(shù)strftime的格式化,可以通過man strftime查看 export HISTTIMEFORMAT="[%F %T][$USER][`who am i 2> /dev/null | gawk '{printf $NF}' | sed -e 's/[()]//g'`]"?
定制樣式效果
?
HISTSIZE
控制內存中的歷史命令的條數(shù)
如:系統(tǒng)的默認1000條,當退出系統(tǒng)的時候會將內存中的歷史命令寫到文件中
HISTFILESIZE
文件中存儲的歷史的條數(shù),如果想禁用寫多少條,可以使用HISTFILESIZE=0來禁止寫入
HISTFILE
默認歷史記錄會寫到用戶的家目錄的.bash_history文件中,我們可以使用這個變量來修改命令被寫入的位置
HISTCONTROL
使用這個變量來控制歷史命令的去重
export HISTCONTROL=ignoredups # (去除連續(xù)的重復指令) export HISTCONTROL=erasedups # (去除所有的重復命令)# 命令:history -c清除所有的歷史命令HISIGNORE
在存儲的時候忽略某些指令,如果寫ls,只會忽略ls,而不會忽略ls -l
例子:export HISIGNORE="pwd:ls:history"
實時記錄參數(shù)(PROMPT_COMMAND)
上面的記錄方式會有一個限制的地方,那就是我們必須要的等到用戶退出的時候才能將歷史命令寫到文件中去,如果有人history -c 命令就被清空了, 下面提供一種實時寫入的方法。
配置PROMPT_COMMAND參數(shù)
export PROMPT_COMMAND='{ date "+%F %T ##### $(who am i | gawk "{print $NF}") #### $(history 1|{ read x cmd;echo "$cmd"; })"; } >> /tmp/history.txt' # 在PROMPT_COMMAND中雖然可以添加時間與獲得ip但是由于單引號與雙引號的問題,特別的麻煩,拆分為下面的export HISTTIMEFORMAT="[$USER][`who am i 2> /dev/null | gawk '{printf $NF}' | sed -e 's/[()]//g'`]"export PROMPT_COMMAND='{ date "+%F %T ##### $(history 1 | { read x cmd;echo "$cmd"; })"; } >> /tmp/history.txt'實例腳本
最后附上一個實例腳本,只要放到初始化文件中保證能夠刷到環(huán)境變量之中即可。
注:下面腳本在設置忽略命令之后,由于緩沖區(qū)保存有一個命令,每次執(zhí)行命令時會觸發(fā)寫入,此時便會重復寫入緩沖區(qū)的這個命令
#設置歷史文件條數(shù) export HISTSIZE=2000 #設置過濾連續(xù)重復指令 export HISTCONTROL=ignoredups #設置忽略指令 export HISIGNORE="pwd:ls:history:cd" #設置history格式 export HISTTIMEFORMAT="[%F %T][$USER][`who am i 2> /dev/null | gawk '{printf $NF}' | sed -e 's/[()]//g'`]"#創(chuàng)建用戶日志目錄與用戶日志文件 ################################################## # #聲明日志目錄變量與日志文件變量(不導出為全局變量,子shell會報錯) export mlogdir=/tmp/history/${USER} export tlogfile=/tmp/history/${USER}/history.$(date +%F).log # #判斷目錄的是否存在、權限和文件是否存在、權限 # if [ -d "${mlogdir}" ] thenif [ -f "${tlogfile}" ]thenif [ -w "${tlogfile}" ]thenecho -nelsechmod a+w ${tlogfile}fielsetouch ${tlogfile}chmod a+w ${tlogfile}fi elsemkdir -p ${mlogdir}touch ${tlogfile}chmod a+w ${tlogfile} fi #記錄shell執(zhí)行的每一條命令 export PROMPT_COMMAND='{ echo "##### $(history 1 | { read x cmd;echo "$cmd"; })"; } >> ${tlogfile}'轉載于:https://www.cnblogs.com/h-zhang/p/10706737.html
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的历史命令与实时记录(redhat6.8)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C#基础加强(7)之ref与out
- 下一篇: Golang 入门 : 数组