用于检测我的服务器何时关闭或脱机的 Bash 脚本

Md *_*man 21 monitoring uptime

背景:当我的服务器关闭时,我需要收到警报。当服务器关闭时,Sysload 收集器可能无法发送任何警报。为了在服务器关闭时收到警报,我有一个外部源(服务器)来检测它。

问题:有什么方法(我更喜欢 bash 脚本)来检测我的服务器何时关闭或脱机并发送警报消息(电子邮件 + 短信)?

Joh*_*nny 28

如果你有一个单独的服务器来运行你的检查脚本,像这样的事情会做一个简单的 Ping 测试,看看服务器是否还活着:

#!/bin/bash
SERVERIP=192.168.2.3
NOTIFYEMAIL=test@example.com

ping -c 3 $SERVERIP > /dev/null 2>&1
if [ $? -ne 0 ]
then
   # Use your favorite mailer here:
   mailx -s "Server $SERVERIP is down" -t "$NOTIFYEMAIL" < /dev/null 
fi
Run Code Online (Sandbox Code Playgroud)

您可以 cron 脚本定期运行。

如果您没有 mailx,则必须用您拥有的任何命令行电子邮件程序替换该行,并可能更改选项。如果您的运营商提供了 SMS 电子邮件地址,您可以将电子邮件发送到该地址。例如,对于 AT&T,如果您向电话号码@txt.att.net 发送电子邮件,它会将电子邮件发送到您的手机。

以下是发送到 SMS 网关的电子邮件列表:

http://en.wikipedia.org/wiki/List_of_SMS_gateways

如果您的服务器是可公开访问的网络服务器,则有一些免费服务可以监控您的网站并在它关闭时提醒您,请在网络上搜索免费网站监控以找到一些服务。

  • 您应该测试您关心服务器所做的任何事情,而不是 ping 服务器。例如,如果它是一个邮件服务器,它成功地发送和接收邮件就更为重要。 (4认同)

jip*_*pie 9

Ping 是一种选择,但在很多情况下,一台机器将能够发送 ping 回复,而它所涉及的实际服务器已关闭。最好做一个端到端的测试。在下面的示例中,从网络服务器请求一个页面。

如果它是一个网络服务器,它看起来像这样:

#!/bin/bash
wget -qO /dev/null 'http://webserver/some_existing_short_document.html' || {
    echo "Webserver down"
    # another mailer example
    sendemail -s mailserverip -f 'from@localhost' -t 'user@localhost' -u 'Webserver down' -m 'The webserver is down'
}
Run Code Online (Sandbox Code Playgroud)

如果你把html文件改成php文件,用de php脚本测试数据库连接、文件系统等,你甚至可以测试服务器的更多方面。这样你就可以开始主动监控机器(在它们导致服务器崩溃之前查看问题)。

与检查邮件服务器类似,但无需请求网页,只需通过邮件服务器发送电子邮件,然后查看是否在邮箱中收到


小智 5

这是我解决同样问题的方法

#!/bin/bash
NOTIFYEMAIL=<your email>
SMSEMAIL=<cell phone number @ sms-gateway>
SENDEREMAIL=alert@localhost
SERVER=http://127.0.0.1/
PAUSE=60
FAILED=0
DEBUG=0

while true 
do
/usr/bin/curl -sSf $SERVER > /dev/null 2>&1
CS=$?
# For debugging purposes
if [ $DEBUG -eq 1 ]
then
    echo "STATUS = $CS"
    echo "FAILED = $FAILED"
    if [ $CS -ne 0 ]
    then
        echo "$SERVER is down"

    elif [ $CS -eq 0 ]
    then
        echo "$SERVER is up"
    fi
fi

# If the server is down and no alert is sent - alert
if [ $CS -ne 0 ] && [ $FAILED -eq 0 ]
then
    FAILED=1
    if [ $DEBUG -eq 1 ]
    then
        echo "$SERVER failed"
    fi
    if [ $DEBUG = 0 ]
    then
        echo "$SERVER went down $(date)" | /usr/bin/mailx -s "$SERVER went down" -r "$SENDEREMAIL" "$SMSEMAIL" 
        echo "$SERVER went down $(date)" | /usr/bin/mailx -s "$SERVER went down" -r "$SENDEREMAIL" "$NOTIFYEMAIL" 
    fi

# If the server is back up and no alert is sent - alert
elif [ $CS -eq 0 ] && [ $FAILED -eq 1 ]
then
    FAILED=0
    if [ $DEBUG -eq 1 ]
    then
        echo "$SERVER is back up"
    fi
    if [ $DEBUG = 0 ]
    then
        echo "$SERVER is back up $(date)" | /usr/bin/mailx -s "$SERVER is back up again" -r "$SENDEREMAIL" "$SMSEMAIL"
        echo "$SERVER is back up $(date)" | /usr/bin/mailx -s "$SERVER is back up again" -r "$SENDEREMAIL" "$NOTIFYEMAIL"
    fi
fi
sleep $PAUSE
done
Run Code Online (Sandbox Code Playgroud)