欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

linux中mysql备份shell脚本代码

程序员文章站 2023-11-22 23:17:10
第一步:在你的linux服务器中定义备份目录: 复制代码 代码如下: mkdir /var/lib/mysqlbackup cd /var/lib/mysqlbackup...

第一步:在你的linux服务器中定义备份目录:

复制代码 代码如下:

mkdir /var/lib/mysqlbackup
cd /var/lib/mysqlbackup

第二步:下面是最重要的一步了,就是写定时备份脚本。

复制代码 代码如下:

vi dbbackup.sh

代码文件如下

复制代码 代码如下:

#!/bin/sh
# mysql data backup script
#
# use mysqldump --help,get more detail.
#
bakdir=/root/back/ysqlbackup
logfile=/root/back/mysql/mysqlbak.log
date=`date +%y%m%d%h%m%s`
echo " " >> $logfile
echo " " >> $logfile
echo "-------------------------------------------" >> $logfile
echo $(date +"%y-%m-%d %h:%m:%s") >> $logfile
echo "--------------------------" >> $logfile
cd $bakdir
dumpfile=$date.sql
gzdumpfile=$date.sql.tar.gz
/usr/local/bin/mysqldump -u user -pname  --database -h 127.0.0.1 db> $dumpfile
echo "dump done" >> $logfile
tar czvf $gzdumpfile $dumpfile >> $logfile 2>&1
echo "[$gzdumpfile]backup success!" >> $logfile
rm -f $dumpfile
#cd $bakdir/daily
cd $bakdir  
echo "backup done!"
echo "please check $bakdir directory!"
echo "copy it to your local disk or ftp to somewhere !!!"
find $bakdir -ctime +30 -exec rm {} ;
echo "delete file over 30 days"

友情提示:其中user,name和db请根据自己的情况修改

保存退出,然后把这个文件赋予可执行的权限:

复制代码 代码如下:

#chmod 777 mysqlautobackup.sh

用crontab定时执行备份脚本代码:

crontab -e

若每天下午3点20备份,添加如下代码,

代码:

复制代码 代码如下:
20 15 * * * /var/lib/mysqlbackup/dbbackup.sh

这样就搞定了,每天会定时帮你备份mysql数据库了。