备份 MySQL 数据库
2021/7/27 19:05:48
本文主要是介绍备份 MySQL 数据库,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 一、备份MySQL
- 二、还原 MySQL
- 三、3 种实现方法
- 1、shell 脚本
- ①、描述
- ②、脚本
- ③、执行脚本
- ④、docker 容器
- ⑤、开启定时任务
- 2、Java 代码
一、备份MySQL
备份 MySQL 数据库核心就是使用 mysqldump 命令,如;
mysqldump -h127.0.0.1 -P3306 -utest -p123456 student > I:\sql\2021-07-27_14-19-14\student.sql
注意:使用备份命令需要开启相关数据库权限,如下:我的数据库比较简单,只需要开启三个权限
备份 MySQL 必要权限,参考我的另一篇博客 https://blog.csdn.net/qq_41538097/article/details/118928032
二、还原 MySQL
还原 mysql 方法比较多,可以使用 可视化工具导入,或者使用 source 命令导入,下面说说和备份命令相对的还原命令
mysql -h127.0.0.1 -P3306 -utest -p123456 student < 2021-07-27_14-19-04\student.sql
注意以下几点
- 需要还原的 sql 文件存在
- 还原需要保证数据库存在
- 还原需要开启必要的权限,具体的权限根据数据库内容不同,可自行开启,如果想偷个懒,使用 root 用户即可(一般 root 用户开启了所有的权限)
如果要使用脚本实现,可参考备份脚本自行实现
三、3 种实现方法
1、shell 脚本
①、描述
- 备份 mysql 数据库
- 凌晨一点执行 shell 脚本
- 删除超过七天的备份
②、脚本
#!/bin/bash dateBackup=$(date +%Y-%m-%d_%H:%M:%S) dir="/root/backupDB/sql/${dateBackup}" if [ ! -d "${dir}" ] then mkdir ${dir} echo "创建文件夹成功" else echo "文件夹已经存在" fi # 需要备份的数据库名 dbNames=(mybatis mybatis-plus) for dbName in ${dbNames[@]} do # 备份MySQL, 1>> 为正常输出,2>> 为错误或者警告输出到日志文件 mysqldump -utest -p123456 ${dbName} 1>> ${dir}/${dbName}.sql 2>> /root/backupDB/log/${dateBackup}.log # 压缩文件 解压为 gzip -d mybatis.sql.gz gzip ${dir}/${dbName}.sql done # 删除超过七天的 sql 备份 find /root/backupDB/sql -mtime +7 -name "*_*" -exec rm -rf {} \; #删除超过七天的 日志 find /root/backupDB/log -mtime +7 -name "*.log" -exec rm -rf {} \;
③、执行脚本
可以使用 chmod 777 backup.sh 添加执行权限, ./backup.sh 启动
或者
使用 sh ./backup.sh 启动执行脚本生成目录如下
④、docker 容器
如果你的 mysql 是 docker 容器,则需要修改上面的 mysqldump 备份命令如下
docker exec -i 111122223333 /bin/bash -c 'mysqldump -utest -p123456 ${dbName} 1>> ${dir}/${dbName}.sql 2>> /root/backupDB/log/${dateBackup}.log'
可以在启动时加一个挂载目录,使用 docker 自行修改上面的脚本路径
⑤、开启定时任务
如果上面的脚本可以正常执行,下面开启定时任务,固定在每天凌晨一点执行
如果没有 crontab 命令自行百度,cron 表达式不清楚的自行百度
- 1、添加定时任务
crontab -e- 2、凌晨 01:00 分执行 /root/backupDB/backup.sh 文件
0 1 * * * /root/backupDB/backup.sh- 3、查看定时任务
crontab -l- 4、查看定时任务日志
tail -f /var/loxg/cron- 5、crond 服务
开启、关闭、重启 可以使用 systemctl start、stop、restart crond
添加定时任务,记得重启 crond 服务,systemctl restart crond
2、Java 代码
这种用的不多
public class TestBackup { public static void main(String[] args) throws Exception { dbBackUp("111.111.111.111", "test", "123456", "3306", "mybatis,mybatis-plus", "I:\\spring\\sendsms\\"); //reduction("111.111.111.111", "3306", "root", "123456", "mybatis-plus", "2021-07-27_14-19-04/mybatis-plus.sql"); } public static void dbBackUp(String host, String userName, String password, String port, String dbNames, String backupPath) { String format = new SimpleDateFormat("yyyy-MM-dd_HH-mm-ss").format(new Date()); boolean mkdir = new File(format).mkdir(); if (!mkdir) return; String[] dbNameArray = dbNames.split(","); for (String dbName : dbNameArray) { String pathSql = backupPath + format + "\\" + dbName + ".sql"; String cmd = "cmd /c mysqldump" + " -h" + host + " -P" + port + " -u" + userName + " -p" + password + " " + dbName + " > " + pathSql; System.out.println("cmd命令为:" + cmd); try { Process process = Runtime.getRuntime().exec(cmd); if (process.waitFor() == 0) { System.out.println(dbName + "数据库备份成功!"); } else { System.out.println(dbName + "数据库备份失败!"); } } catch (IOException | InterruptedException e) { e.printStackTrace(); } } } public static void reduction(String host, String port, String userName, String password, String databaseName, String fileName) throws Exception { File datafile = new File(fileName); if (!datafile.exists()) { System.out.println(fileName + "文件不存在,请检查"); return; } String cmd = "cmd /c mysql -h" + host + " -P" + port + " -u" + userName + " -p" + password + " " + databaseName + " < " + datafile; System.out.println(cmd); //拼接cmd命令 Process exec = Runtime.getRuntime().exec(cmd); if (exec.waitFor() == 0) { System.out.println(databaseName + "数据库还原成功,还原的文件为:" + datafile); } else { System.out.println(databaseName + "数据库还原失败"); } } }
运行结果如下,备份成功
这篇关于备份 MySQL 数据库的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-04部署MySQL集群项目实战:新手入门教程
- 2024-11-04如何部署MySQL集群资料:新手入门指南
- 2024-11-02MySQL集群项目实战:新手入门指南
- 2024-11-02初学者指南:部署MySQL集群资料
- 2024-11-01部署MySQL集群教程:新手入门指南
- 2024-11-01如何部署MySQL集群:新手入门教程
- 2024-11-01部署MySQL集群学习:新手入门教程
- 2024-11-01部署MySQL集群入门:新手必读指南
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南