您的位置:首页 > 运维架构 > Linux

在系统创建新用户时发送邮件的 Bash 脚本 | Linux 中国

2019-08-08 07:15 591 查看


目前市场上有许多开源监测工具可用于监控 Linux 系统的性能。当系统到达指定的阈值时,它将发送邮件提醒。但我不认为它们可以选择监控新用户创建活动,并发送提醒。
-- Magesh Maruthamuthu

目前市场上有许多开源监测工具可用于监控 Linux 系统的性能。当系统到达指定的阈值时,它将发送邮件提醒。

它会监控 CPU 利用率、内存利用率、交换内存利用率、磁盘空间利用率等所有内容。但我不认为它们可以选择监控新用户创建活动,并发送提醒。

如果没有,这并不重要,因为我们可以编写自己的 bash 脚本来实现这一点。

我们过去写了许多有用的 shell 脚本。如果要查看它们,请点击以下链接。

◈ 如何使用 shell 脚本自动化执行日常任务?

这个脚本做了什么?它监测 /var/log/secure 文件,并在系统创建新帐户时提醒管理员。

我们不会经常运行此脚本,因为创建用户不经常发生。但是,我打算一天运行一次这个脚本。因此,我们可以获得有关用户创建的综合报告。

如果在昨天的 /var/log/secure 中找到了 “useradd” 字符串,那么该脚本将向指定的邮箱发送邮件提醒,其中包含了新用户的详细信息。

注意:你需要更改邮箱而不是使用我们的邮箱。

  1. # vi /opt/scripts/new-user.sh
  1. #!/bin/bash
  2. #Set the variable which equal to zero
  3. prev_count=0
  4. count=$(grep -i "`date --date='yesterday' '+%b %e'`" /var/log/secure | egrep -wi 'useradd' | wc -l)
  5. if [ "$prev_count" -lt "$count" ] ; then
  6. # Send a mail to given email id when errors found in log
  7. SUBJECT="ATTENTION: New User Account is created on server : `date --date='yesterday' '+%b %e'`"
  8. # This is a temp file, which is created to store the email message.
  9. MESSAGE="/tmp/new-user-logs.txt"
  10. TO="2daygeek@gmail.com"
  11. echo "Hostname: `hostname`" >> $MESSAGE
  12. echo -e "\n" >> $MESSAGE
  13. echo "The New User Details are below." >> $MESSAGE
  14. echo "+------------------------------+" >> $MESSAGE
  15. grep -i "`date --date='yesterday' '+%b %e'`" /var/log/secure | egrep -wi 'useradd' | grep -v 'failed adding'| awk '{print $4,$8}' | uniq | sed 's/,/ /' >> $MESSAGE
  16. echo "+------------------------------+" >> $MESSAGE
  17. mail -s "$SUBJECT" "$TO" < $MESSAGE
  18. rm $MESSAGE
  19. fi

给 new-user.sh 添加可执行权限。

  1. $ chmod +x /opt/scripts/new-user.sh

最后添加一个 cron 任务来自动化执行它。它会在每天 7 点运行。

  1. # crontab -e
  2. 0 7 * * * /bin/bash /opt/scripts/new-user.sh

注意:你将在每天 7 点收到一封邮件提醒,但这是昨天的日志。

你将会看到类似下面的邮件提醒。

  1. # cat /tmp/logs.txt
  2. Hostname: 2g.server10.com
  3. The New User Details are below.
  4. +------------------------------+
  5. 2g.server10.com name=magesh
  6. 2g.server10.com name=daygeek
  7. +------------------------------+

via: https://www.2daygeek.com/linux-bash-script-to-monitor-user-creation-send-email/

作者:Magesh Maruthamuthu 选题:lujun9972 译者:geekpi 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

😻:还在看吗?
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: