Linux bash运维操作日志审计(单服务器)

Posted wangyun1

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux bash运维操作日志审计(单服务器)相关的知识,希望对你有一定的参考价值。

目前公司有几台机器比较重要,需要把所有用户的操作记录下来,于是就是参照资料来完成

1. vim /etc/profile.d/oplogrc.sh

技术分享图片
logdir=/opt/oplog
userdir=$logdir/${LOGNAME}
DT=`date +"%Y%m%d"`

export HISTFILE="/$userdir/history.$DT"
export HISTTIMEFORMAT="%F %T :"
export HISTSIZE=128
export HISTFILESIZE=8192
export PROMPT_COMMAND="history -a"

if [ ! -d $logdir ];then
    mkdir -p $logdir
    chmod 777 $logdir
fi

if [ ! -d $userdir ];then
    mkdir -p $userdir
    chmod 300 $userdir
fi

shopt -s histappend

readonly HISTFILE
readonly HISTTIMEFORMAT
readonly HISTSIZE
readonly HISTFILESIZE
readonly PROMPT_COMMAND
readonly HISTCMD
readonly HISTCONTROL
技术分享图片

该文件定义了记录history的位置,目录,并且设置这些环境变量只读

2. vim /opt/shells/optlogcron.sh    

技术分享图片
logdir=/opt/oplog
userdir=$(ls $logdir)
DT=`date +"%Y%m%d"`
for user in $userdir;do
    hisfile="$logdir/$user/history.$DT"
    if [ ! -f $hisfile ];then
        touch $hisfile
        chown $user:$user $hisfile
        chmod 300 $hisfile
        chattr +a $hisfile
    else
        lsattr $hisfile | awk ‘{ print $1 }‘ | grep -v "a" &> /dev/null && chmod 300 $hisfile && chattr +a $hisfile
    fi
    find . -type f -size 0 -mtime +1 -exec chattr -a {} \;
    find . -type f -size 0 -mtime +1 -exec rm -f {} \;
done
技术分享图片

o该文件主要用途是让日志文件加上特殊权限,防止被删除,清楚一天前的空日志。

3. crontab -e

*/1 * * * * /opt/shells/oplogcron.sh &> /dev/null    

每分钟执行一下。

以上是关于Linux bash运维操作日志审计(单服务器)的主要内容,如果未能解决你的问题,请参考以下文章

Linux运维人员共用root帐户权限审计

Linux 之不同运维人员共用root 账户权限审计

bash和mysql的代码一个低成本实用性能高的日志审计方案

运维日志审计是什么意思?用什么工具好?

运维日志审计是什么意思?用什么工具好?

Linux服务器集群只允许堡垒机SSH登录