在Linux服务器环境维护中,通常会mysqldump命令来备份数据库,通常命令如下
mysqldump -uusername -ppassword --databases databasename > dumpfilename
基于上述命令,我们可以将导出的sql文件进行压缩和管理,编写为shell脚本后,整体shell脚本如下
#!/bin/bash
BakDir=/home/bak/mysql-back/database-back
LogFile=/home/bak/mysql-back/mysql_buckup.log
Date=`date +%Y%m%d`
Begin=`date +"%Y年%m月%d日 %H:%M:%S"`
# 修改为自己的数据库名称
DB=database
DumpFile=$DB$Date.sql
GZDumpFile=$DB-$Date.sql.tar.gz
# 检查备份目录是否存在
if [ -d "$BakDir" ]
then echo "[INFO]开始执行数据库备份程序"
else sudo mkdir $BakDir
fi
# 下面的/usr/bin是mysql安装目录的bin目录,如果你修改过直接使用你的目录即可
# 执行备份命令
cd $BakDir
# 此处修改为自己的root用户密码
echo "[INFO] /usr/bin/mysqldump -uroot -ppassword --databases $DB > $DumpFile" >> $LogFile
/usr/bin/mysqldump -uroot -ppassword --databases $DB > $DumpFile
mv $DumpFile $BakDir
cd $BakDir
# 对备份数据进行压缩
echo "[INFO] tar czvf $GZDumpFile $DumpFile" >> $LogFile
tar czvf $GZDumpFile $DumpFile
# 删除备份的sql文件
echo "[INFO] rm $DumpFile" >> $LogFile
rm $DumpFile
# 备份 备份的sql文件到指定目录
echo "[INFO] mv $GZDumpFile $BakDir" >> $LogFile
mv $GZDumpFile $BakDir
Last=`date +"%Y年%m月%d日 %H:%M:%S"`
echo 开始:$Begin 结束:$Last $GZDumpFile 执行成功 >> $LogFile
#清理备份,保留30天的备份
find $BakDir/* -mtime +30 -exec rm { } \;
echo "[INFO]备份任务执行结束"
检验:
使用 shmod 777 bakmysql.sh
来使文件变成可执行文件,使用./bakmysql.sh
来执行此文件,执行之后可以在自己定义的备份目录下找到备份成功的压缩包
定时任务
Linux服务器中一般使用crontab来自动执行定时任务。
查看cron表达式的一些基本命令
service crond start //启动服务
service crond stop //关闭服务
service crond restart //重启服务
service crond reload //重新载入配置
service crond status //查看服务状态
使用service crond start
来开启服务
使用 vi /etc/crontab
来查看配置文件(不要在此处进行配置任务,此处类似于是crontab的说明书)
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
# 进入crontab的编辑配置
crontab -e
# 此处配置的意思为每天晚上七点半定时执行shell文件
30 19 * * * /home/bak/mysql-back/bakmysql.sh
# 通过crontab -l查看已配置的定时任务
crontab -l
使用service crond reload
对crontab进行重新载入