新浪新闻客户端

用 Bash 脚本发送新用户帐户创建的邮件 | Linux 中国

用 Bash 脚本发送新用户帐户创建的邮件 | Linux 中国
2019年09月20日 11:51 新浪网 作者 Linux中国

  

用 Bash 脚本发送新用户帐户创建的邮件 | Linux 中国

  出于某些原因,你可能需要跟踪 Linux 上的新用户创建信息。同时,你可能需要通过邮件发送详细信息。这或许是审计目标的一部分,或者安全团队出于跟踪目的可能希望对此进行监控。

  -- Magesh Maruthamuthu

  出于某些原因,你可能需要跟踪 Linux 上的新用户创建信息。同时,你可能需要通过邮件发送详细信息。这或许是审计目标的一部分,或者安全团队出于跟踪目的可能希望对此进行监控。

  我们可以通过其他方式进行此操作,正如我们在上一篇文章中已经描述的那样。

  ◈ 在系统中创建新用户帐户时发送邮件的 Bash 脚本

  Linux 有许多开源监控工具可以使用。但我不认为他们有办法跟踪新用户创建过程,并在发生时提醒管理员。

  那么我们怎样才能做到这一点?

  我们可以编写自己的 Bash 脚本来实现这一目标。我们过去写过许多有用的 shell 脚本。如果你想了解,请进入下面的链接。

  ◈ 如何使用 shell 脚本自动化日常活动?

  这个脚本做了什么?

  这将每天两次(一天的开始和结束)备份 /etc/passwd 文件,这将使你能够获取指定日期的新用户创建详细信息。

  我们需要添加以下两个 cron 任务来复制 /etc/passwd 文件。

  # crontab -e

  10***cp/etc/passwd/opt/scripts/passwd-start-$(date+"%Y-%m-%d")

  5923***cp/etc/passwd/opt/scripts/passwd-end-$(date+"%Y-%m-%d")

  它使用 diff 命令来检测文件之间的差异,如果发现与昨日有任何差异,脚本将向指定 email 发送新用户详细信息。

  我们不用经常运行此脚本,因为用户创建不经常发生。但是,我们计划每天运行一次此脚本。

  这样,你可以获得有关新用户创建的综合报告。

  注意:我们在脚本中使用了我们的电子邮件地址进行演示。因此,我们要求你用自己的电子邮件地址。

  #vi/opt/scripts/new-user-detail.sh

  #!/bin/bash

  mv/opt/scripts/passwd-start-$(date--date='yesterday''+%Y-%m-%d')/opt/scripts/passwd-start

  mv/opt/scripts/passwd-end-$(date--date='yesterday''+%Y-%m-%d')/opt/scripts/passwd-end

  ucount=$(diff/opt/scripts/passwd-start /opt/scripts/passwd-end|grep">"|cut-d":"-f6 |cut-d"/"-f3 |wc-l)

  if[ $ucount -gt 0]

  then

  SUBJECT="ATTENTION: New User Account is created on server : `date --date='yesterday' '+%b %e'`"

  MESSAGE="/tmp/new-user-logs.txt"

  TO="2daygeek@gmail.com"

  echo"Hostname: `hostname`">> $MESSAGE

  echo-e "\n">> $MESSAGE

  echo"The New User Details are below.">> $MESSAGE

  echo"+------------------------------+">> $MESSAGE

  diff/opt/scripts/passwd-start /opt/scripts/passwd-end|grep">"|cut-d":"-f6 |cut-d"/"-f3 >> $MESSAGE

  echo"+------------------------------+">> $MESSAGE

  mail -s "$SUBJECT""$TO"

  rm $MESSAGE

  fi

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

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

  最后添加一个 cron 任务来自动执行此操作。它在每天早上 7 点运行。

  # crontab -e

  07***/bin/bash/opt/scripts/new-user.sh

  注意:你会在每天早上 7 点都会收到一封关于昨日详情的邮件提醒。

  输出:输出与下面的输出相同。

  #cat/tmp/new-user-logs.txt

  Hostname:CentOS.2daygeek.com

  TheNewUserDetails are below.

特别声明:以上文章内容仅代表作者本人观点,不代表新浪网观点或立场。如有关于作品内容、版权或其它问题请于作品发表后的30日内与新浪网联系。
脚本Linux
权利保护声明页/Notice to Right Holders

举报邮箱:jubao@vip.sina.com

Copyright © 1996-2024 SINA Corporation

All Rights Reserved 新浪公司 版权所有