这篇文章主要介绍了Mysql备份多个数据库代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
备份数据脚本
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#!/bin/bash
# date 是linux的一个命令 date [参数] [+格式]
time =` date +%Y_%m_%d_%H_%M_%S `
# 备份输出路径
backupdir=/home/backup/
# 备份文件路径
filedir=/home/my_app/files/
# 用sql语句取出所有以 'test' 开头的数据库。将指令通过管道传递给mysql客户端;-N表示不输出结果的表头及结尾,得到的结果是纯粹的数据集
databases=(`echo 'show databases like "test%";' | mysql -N -uroot -proot`)
# 将mysqldump的输出文件通过管道传给gzip压缩,gzip是不能保存原文件且不能压缩目录的
mysqldump -uroot -proot --databases ${databases[*]} | gzip > $backupdir/$time.sql.gz
# 备份文件。zip [压缩输出文件] [被压缩文件]
zip -r $backupdir/$ time .zip $filedir
# 删除7天前的备份文件
find $backupdir -mtime +7 - name "*" - exec rm -rf {} \;
|
然后设置crontab在每天凌晨运行备份脚本即可
数据恢复
1
|
mysql -u root -p DATABESE_NAME < dump.sql
|
或者连接mysql客户端
1
|
mysql> source dump.sql
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/luozx207/p/11721226.html