linux下如何监控服务器的存活状态

这篇文章主要讲解了“linux下如何监控服务器的存活状态”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“linux下如何监控服务器的存活状态”吧!

润州网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站设计等网站项目制作,到程序开发,运营维护。创新互联自2013年起到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联

简单邮件传输协议 (Simple Mail Transfer Protocol, SMTP) 是在Internet传输email的事实标准,
SMTP是一个相对简单的基于文本的协议。在其之上指定了一条消息的一个或多个接收者,然后消息文本会
被传输。SMTP使用TCP端口25。
一、配置环境
[root@ser ~]# cat /etc/redhat-release 
CentOS Linux release 7.5.1804 (Core) 
#查看系统环境
[root@ser ~]# systemctl stop firewalld
#停止firewall防火墙服务
[root@ser ~]# systemctl disable firewalld
#禁止firewall防火墙服务开机自动启动功能
[root@ser ~]# firewall-cmd --state
not running
#查看防火墙运行状态,确认防火墙被关闭。
vi /etc/selinux/config
#SELINUX=enforcing
#SELINUXTYPE=targeted
SELINUX=disabled
:wq! 
#关闭selinux,保存退出
[root@ser ~]# setenforce 0
#临时关闭selinux,重启失效
[root@ser ~]# getenforce
Disabled
#查看selinux状态,确认已关闭
二、下载软件,并安装相关依赖的perl组件
[root@ser ~]# yum -y install perl-Net-SSLeay perl-IO-Socket-SSL
#安装依赖
[root@ser ~]# wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz
#下载安装包
[root@ser ~]# tar -zxf sendEmail-v1.560.tar.gz
#解压安装包
[root@ser ~]# cd sendEmail-v1.56/
[root@ser sendEmail-v1.56]# ls
CHANGELOG  README  README-BR.txt  sendEmail  sendEmail.pl  TODO
#进入目录sendEmail-v1.56/
[root@ser sendEmail-v1.56]# cp sendEmail /usr/local/bin/sendEmail
[root@ser sendEmail-v1.56]# chown root:root /usr/local/bin/sendEmail
[root@ser sendEmail-v1.56]# ll /usr/local/bin/sendEmail 
-rwxr-xr-x 1 root root 80183 Jul 31 15:14 /usr/local/bin/sendEmail
#将sendEmail复制到执行目录/usr/local/bin/下,并赋予root用户权限、属组权限
三、创建脚本并赋予脚本执行权限
[root@ser ~]# cd
[root@ser ~]# pwd
/root
#返回/root
[root@ser ~]# vim mail.sh
#!/bin/bash
to=$1
subject=$2
body=$3
/usr/local/bin/sendEmail -o tls=auto  -f ******@qq.com -t "$to" -s smtp.qq.com -u "$subject" 
-o message-content-type=html -o message-charset=utf8 -xu ******@qq.com -xp ****** -m "$body"
#脚本中  -f ********@qq.com表示发件人邮箱,-s smtp.qq.com 表示邮件的smtp服务器
#本文中使用腾讯qq邮箱,使用其他邮箱服务器需要修改
# -xu ********@qq.com 表示发件人邮箱的用户名,-xp ********表示邮件协议授权密钥
[root@ser ~]# chmod +x mail.sh
#执行脚本测试发送邮件
[root@ser ~]# ./mail.sh chao.il@qq.com test 123
        test
        发件人:**<********@qq.com>     
        时   间:2019年9月12日(星期四) 下午3:50 (UTC+0:00 伦敦、都柏林、里斯本时间)    
        收件人:** <********@qq.com>
        123
        #收到的测试邮件
四、常见问题及处理:
1、当进行邮件测试时,出现invalid SSL_version ******/IO/Socket/SSL.pm line 444这样的报错时,
原因是sendEmail软件和perl里面的SSL版本不兼容导致,通过修改/usr/local/bin/sendEmail文件第
1906行,不指定SSL版本,原始文件为  if (! IO::Socket::SSL->start_SSL($SERVER, SSL_version
=> ‘SSLv3 TLSv1‘)) {     更改后为  if (! IO::Socket::SSL->start_SSL($SERVER)) {
2、当进行邮件测试,出现ERROR => SMTP-AUTH: Authentication to smtp.qq.com:25 failed这样
的报错时,原因是邮箱要求使用第三方客户端发送邮件是必须使用授权码登录的,使用帐号密码验证时,授
权码需要登录邮箱设置中查找,有些邮件服务器需要先开启POP3服务。
五、编写shell脚本进行服务器在线状态监控
[root@ser ~]# vim CheckNetwork.sh 
#!/bin/bash
tt1=172.20.220.20     
#定义服务器一
tt2=172.20.11.1         
#定义服务器二
while true
#while(true)是一个无穷循环语句  
#我们必须在他的循环语句内部加入一个判断,当他达到了什么要求就会跳出
do
        ping -c 5 $tt1 >/dev/null
                    #用ping命令来探测远程机是否存活
                    if [ $? -eq 0 ];then
                    #shell脚本中$?是指上一次命令执行的成功或者失败的状态。如果成功就是0,失败为1。
                    #语句if [ $? -eq 0 ] 是判断if语句的上一个命令执行如果失败就执行if中的语句,否则就执行else中的内容。

                            echo `date +%F-%T` "  $tt1 is yes" >> ip_yes.txt
                            #追加当前时间和服务器IP is yes 到ip_yes.txt,此处ip_yes.txt用做正确日志文件 
                    else
                            echo `date +%F-%T` "  $tt1 is Error" >> ip_no.txt
                            #追加当前时间和服务器IP is Error到ip_no.txt,此处ip_no.txt用做错误日志文件
                            /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" 
                            /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" 
                            /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" 
                            /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error"
                            #发送邮件给以上的邮件地址
        sleep 5
        #休眠5秒
fi
        ping -c 5 $tt2 >/dev/null
                    if [ $? -eq 0 ];then    
                            echo `date +%F-%T` "  $tt2 is yes" >> ip_yes.txt
                    else
                            echo `date +%F-%T` "  $tt2 is Error" >> ip_no.txt 
                            /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error"
                            /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error"
                            /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error"
                            /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error"
        sleep 5
fi
        kill -9 `ps aux | grep CheckNetwork | grep -v grep | awk '{print $2}'`
        #执行脚本后,杀死此脚本的进程,防止重复执行脚本。
done    
[root@ser ~]# crontab -l
*/15 8-18 * * * /usr/bin/bash /root/CheckNetwork.sh
#设置定时任务,8点到18点每15分钟执行CheckNetwork.sh。(时间请根据需求设定)
下面为报警邮件信息
        服务器错误
        发件人:** <********@qq.com>        
        时   间:2019年9月12日(星期四) 下午4:45 (UTC+0:00 伦敦、都柏林、里斯本时间) 
        收件人:** <********@qq.com>
        2019-09-12-12:45:19----益辉 172.20.11.1 is Error

感谢各位的阅读,以上就是“linux下如何监控服务器的存活状态”的内容了,经过本文的学习后,相信大家对linux下如何监控服务器的存活状态这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


本文标题:linux下如何监控服务器的存活状态
本文网址:http://pwwzsj.com/article/joshge.html