题目
一、判断当前磁盘剩余空间是否有20G,如果小于20G,则将报警邮件发送给管理员,每天检查一次磁盘剩余空间。
二、判断web服务是否运行(1、查看进程的方式判断该程序是否运行,2、通过查看端口的方式判断该程序是否运行),如果没有运行,则启动该服务并配置防火墙规则。
三、使用curl命令访问第二题的web服务,看能否正常访问,如果能正常访问,则返回web server is running;如果不能正常访问,返回12状态码。
一、判断当前磁盘剩余空间是否有20G,如果小于20G,则将报警邮件发送给管理员,每天检查一次磁盘剩余空间。
分析:查看磁盘剩余空间需要使用命令df命令。发送邮件需要安装邮件服务器(安装服务端:yum install postfix -y ;安装客户端:yum install mailx -y;开启邮件服务并开机自启:systemctl enable postfix --now)。每天检查一次需要做计划任务。
操作:
1、确保邮件服务和crond服务正常运行
2、编写脚本
[root@client_2 homework3]# vim df_mail_crond.sh
#!/bin/bash
free_MB=`df -m / | awk '/\//{print $4}'`
free_GB=$[$free_MB/1024]
if [[ $free < 20480 ]] ;then
echo "Warning:The current disk space remaining is ${free_GB}G that less than 20G." | mail -s "Warning" root
else
echo "The current disk space remaining is ${free_GB}G.It is enough to use."
fi
3、加可执行权限
[root@client_2 homework3]# chmod a+rx df_mail_crond.sh
4、测试
5、加入计划任务
[root@client_2 homework3]# vim /etc/crontab
0 0 * * * root /root/shell/homework3/df_mail_crond.sh
二、判断web服务是否运行(1、查看进程的方式判断该程序是否运行,2、通过查看端口的方式判断该程序是否运行),如果没有运行,则启动该服务并配置防火墙规则。
需要提前安装httpd包(yum install -y httpd)
查看进程方式:
1、编写脚本(注意脚本名称不要带有httpd字眼,会影响进程数判断 QAQ)
[root@client_2 homework3]# vim apache_start.sh
#!/bin/bash
ps_httpd=`ps -ef | grep httpd | grep -v grep | wc -l`
if [[ $ps_httpd > 0 ]];then
echo "httpd.service is running."
else
systemctl start httpd
systemctl stop firewalld
fi
2、加可执行权限
[root@client_2 homework3]# chmod a+rx apache_start.sh
3、测试
查看端口方式:
1、编写脚本
[root@client_2 homework3]# vim apache_start_port.sh
#!/bin/bash
port80=`ss -lntup | grep -w 80 | wc -l`
if [[ $port80 > 0 ]];then
echo "httpd.service is running."
else
systemctl start httpd
systemctl stop firewalld
fi
2、加可执行权限
[root@client_2 homework3]# chmod a+rx apache_start_port.sh
3、测试
三、使用curl命令访问第二题的web服务,看能否正常访问,如果能正常访问,则返回web server is running;如果不能正常访问,返回12状态码。
1、编写代码
[root@client_2 homework3]# vim web_test.sh
#!/bin/bash
curl -s 192.168.5.130 > /dev/null
if [[ $? = 0 ]];then
echo "web server is running."
else
exit 12
fi
2、加可执行权限
[root@client_2 homework3]# chmod a+rx web_test.sh
3、测试
over~