1.判断当前磁盘剩余空间是否有20G,如果小于20G,则将报警邮件发送给管理员,每天检查一次磁盘剩余空间。
1.下载mailx服务并设置
yum install mailx -y
vim /etc/mail.rc
将下列内容写入文件末尾即可
set from=自己邮箱@qq.com
set smtp=smtp.qq.com
set smtp-auth-user=自己邮箱@qq.com
set smtp-auth-password=自己邮箱授权码
set smtp-auth=login
2.编写脚本内容
vim test1.sh
#!/bin/bash
#Author Happy_Eavry_Day
Free_Space=$( df -m | grep -w "/"| tr -s " " | cut -d " " -f4)
Waring="warning:disk space less then 20G!"
if (($Free_Space<20000))
then
echo "警告不足20G" | mail -s "$Warning" 3388586383@qq.com
fi
3.设置每天检查
vim /etc/crontab
0 0 * * * root/bin/bash /root/test1.sh
4.检查
已收到邮箱内容为准也可以设置检查时间为每时每刻来直接测试
0 0 0 0 0 root/bin/bash /root/test1.sh
2、判断web服务是否运行(1、査看进程的方式判断该程序是否运行,2、通过查看端口的方式判断该程序是否运行),如果没有运行,则启动该服务并配置防火墙规则。
1.代码
vim test2.sh
#!/bin/bash
#Author:Happy_Eavry_Day
num=$(ps -ef | grep nginx | grep -v grep | wc -l)
if (($num>0))
then
echo "nginx is running"
else
echo "nginx is not running,pleas waiting"
yum install nginx -y > /dev/null
# >/dev/null 丢掉反馈消息
systemctl start nginx
systemctl start firewalld
firewall-cmd --permanent --zone=public --add-service=http > /dev/null
firewall-cmd --permanent --zone=public --add-port=80/tcp > /dev/null
firewall-cmd --reload > /dev/null
echo "nginx is already running"
fi
2.测试
3、使用curl命令访问第二题的web服务,看能否正常访问,如果能正常访问,则返回web serveris running;如果不能正常访问,返回12状态码。
1.代码
vim test3.sh
#!/bin/bash
#Author:Happy_Eavry_Day
ip=$(ip a | grep ens33 | grep inet | cut -d / -f1 | tr -s ' ' | cut -d ' ' -f3)
curl -s $ip > /dev/null
if (($?==0))
then
echo "web server is running"
else
echo "web not accessible"
exit 12
fi