Mysql数据库定时全库备份

如下脚本用于mysql全库定时备份

mysql_dump_script.sh

 1 #!/bin/bash
 2 
 3 #保存备份个数,最多保留4个文件
 4 number=4
 5 #备份保存路径
 6 backup_dir=/db/backup_mysql
 7 #日期
 8 dd=`date +%Y-%m-%d-%H-%M-%S`
 9 #备份工具
10 tool=mysqldump
11 #用户名
12 username=root
13 #密码
14 password=yourpassword
15 #将要备份的数据库
16 database_name=mydb
17 
18 #如果文件夹不存在则创建
19 if [ ! -d $backup_dir ]; 
20 then     
21     mkdir -p $backup_dir; 
22 fi
23 
24 #简单写法  mysqldump -u root -p123456 users > /root/mysqlbackup/users-$filename.sql
25 $tool -h127.0.0.1 -u $username -p$password $database_name > $backup_dir/$database_name-$dd.sql
26 
27 #写创建备份日志
28 echo "create $backup_dir/$database_name-$dd.dupm" >> $backup_dir/log.txt
29 
30 #找出需要删除的备份
31 delfile=`ls -l -crt  $backup_dir/*.sql | awk '{print $9 }' | head -1`
32 
33 #判断现在的备份数量是否大于$number
34 count=`ls -l -crt  $backup_dir/*.sql | awk '{print $9 }' | wc -l`
35 
36 if [ $count -gt $number ]
37 then
38   #删除最早生成的备份,只保留number数量的备份
39   rm $delfile
40   #写删除文件日志
41   echo "delete $delfile" >> $backup_dir/log.txt
42 fi

centos 设置crontab

yum install crontabs
systemctl enable crond (设为开机启动)
systemctl start crond(启动crond服务)
systemctl status crond (查看状态)

vi /etc/crontab

添加定时任务

扫描二维码关注公众号,回复: 8450326 查看本文章

加载任务,使之生效:

crontab /etc/crontab

查看任务:

crontab -l

猜你喜欢

转载自www.cnblogs.com/DevinZhang1990/p/12162383.html
今日推荐