热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用shell定时自动备份mysql数据库_MySQL

#!binbashidroot#用户名pwd123456#密码dbsblog.ewsd.cndangjian.ewsd.cnidc.ewsd.cnshangfa.ewsd.cn#数据库名字的列表,多个数据库用空格分开backuppathhomemysqlbackup#保存备份...
使用shell定时自动备份mysql数据库_MySQL

#!/bin/bash
 
id="root" #用户名
pwd="123456" #密码
dbs="blog.ewsd.cn dangjian.ewsd.cn idc.ewsd.cn shangfa.ewsd.cn" #数据库名字的列表,多个数据库用空格分开
backuppath="/home/mysqlbackup" #保存备份的位置
day=30   #保留最近几天的备份
[ ! -d $backuppath ] &&mkdir -p $backuppath  #判断备份目录是否存在,不存时新建目录。
cd $backuppath   #转到备份目录,这句话可以省略。可以直接将路径到命令的也行。
 
backupname=mysql_$(date +%Y-%m-%d)  #生成备份文件的名字的前缀,不带后缀。
for db in $dbs;   #dbs是一个数据名字的集合。遍历所有的数据。
do
 
mysqldump -u$id -p$pwd -S /tmp/mysql.sock $db >$backupname_$db.sql  #备份单个数据为.sql文件。放到当前位置
 
if [ "$?" == "0" ]  #$? 得到上一个shell命令的执行的返回值。0表示执行成功。其他表示错误。并将将结果写入到日志中。
   then
       echo $(date +%Y-%m-%d)" $db  mysqldump sucess">>mysql.log
   else
      echo $(date +%Y-%m-%d)"  $db mysql dump failed">>mysql.log
      exit 0
   fi
done
tar -czf $backupname.tar.gz *.sql #压缩所有sql文件
if [ "$?" == "0" ]
then
   echo $(date +%Y-%m-%d)" tar sucess">>mysql.log
else
   echo $(date +%Y-%m-%d)" tar failed">>mysql.log
   exit 0
fi
rm -f *.sql  #删除所有的sql文件
 
delname=mysql_$(date -d "$day day ago" +%Y-%m-%d).tar.gz  #得到要删除的太旧的备份的名字。
rm -f $delname  #删除文件。

将以上脚本加入定时计划crontab中即可,下载地址 注意脚本的执行权限设置。

以上就是使用shell定时自动备份mysql数据库_MySQL的内容,更多相关内容请关注PHP中文网(www.php1.cn)!

推荐阅读
author-avatar
davidwzw2009413
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有