开发文档:
需求1:实现自动启停服务端,并判断是否成功。
需求2:停止服务端备份MYSQL数据,实现数据备份,为什么要停止服务端备份,因为热备份偶尔会出问题。
需求3:数据备份完成启动服务端,并检查日志判断是否成功。
需求4:启动登陆器网关,并检查日志判断网关是否启动成功。
需求5:完成上述操作,脚本日志及数据库备份文件发送至用户邮箱。
代码实现,展示部分:
#!/bin/bash
#定义变量
TH_PROFILE=/root/mysql
PATH_PROFILE2=/root/log/sshlog.txt
PATH_PROFILE3=/var/lib/mysql/
PATH_PROFILE4=/root/log/stop.log
current_date=`date +%Y%m%d`
file_path=/home/neople/game/log/siroco56/Log$current_date.init
#删除创建临时日志文件
rm -rf /root/log
mkdir -p /root/log
touch /root/log/sshlog.txt
echo "脚本作者:318847139" |tee $PATH_PROFILE2
echo "日志文件创建成功,目录/root/log/sshlog.txt" |tee -a $PATH_PROFILE2
echo "正在安装发邮件所需组件..."
sleep 2
rpm -qa | grep sendmail
if [ $? -eq 0 ];
then
echo "服务已经安装"
else
echo "服务为安装,正在安装"
yum -y install sendmail
fi
sleep 2
rpm -qa | grep mailx
if [ $? -eq 0 ];
then
echo "服务已经安装"
else
echo "服务为安装,正在安装"
yum -y install mailx >/dev/null 2>&1
fi
sleep 2
if [ -f /root/.mail.sh/qq.crt ]
then
echo ""
else
mkdir -p /root/.certs/
sleep 2
echo -n | openssl s_client -connect smtp.qq.com:465 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > ~/.certs/qq.crt
sleep 2
certutil -A -n "GeoTrust SSL CA" -t "C,," -d ~/.certs -i ~/.certs/qq.crt
sleep 2
certutil -A -n "GeoTrust Global CA" -t "C,," -d ~/.certs -i ~/.certs/qq.crt
sleep 2
certutil -L -d /root/.certs
sleep 2
cd /root/.certs/
sleep 2
certutil -A -n "GeoTrust SSL CA - G3" -t "Pu,Pu,Pu" -d ./ -i qq.crt
sleep 2
echo "正在配置邮件系统..."
fi
sleep 2
if [ -f /root/.mail.sh ]
then
echo ""
grep "LOG=/root/log/sshlog.txt" /root/.mail.sh
if [ $? -eq 0 ];
then
echo ""
else
rm -rf /root/.mail.sh
touch /root/.mail.sh
chmod +x /root/.mail.sh
cat <<\EOF > /root/.mail.sh
#!/bin/bash
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
FROM_EMAIL="82633****@qq.com" #发送者的邮箱地址
TO_EMAIL="31884****@qq.com" #接收者的邮箱地址
IP=$(curl http://ifconfig.me)
LOG=/root/log/sshlog.txt
filename=`ls -t /root/mysql |head -n1|awk '{print $0}'`
LOG2=/root/mysql/$filename
echo -e "`date "+%Y-%m-%d %H:%M:%S"` : 已发送日志邮件,有任何异常请联系脚本作者QQ:318847139." | mailx \
-r "<${IP}> <${FROM_EMAIL}>" \
-a ${LOG} \
-a ${LOG2} \
-s "DOF——备份日志" ${TO_EMAIL}
EOF
fi
效果展示:
邮件发送:
查看日志:
该日志是脚本运行日志,已发送至邮箱:
开发这个脚本的目的是:
1.数据备份发到邮箱,最大限度保护数据安全。即便是服务器被入侵,数据库被删档也能轻松恢复。
2.每天凌晨启停一次服务端,释放服务器资源,使服务器运转更为流畅。
3.因服务器环境不同,该脚本需要人为部署,暂不提供一键端。后续开发根据需求可能会提供一键端。