mysql8数据库备份

1、背景

mysql 8备份策略,备份7天,每天全量备份一次。

2、方案

在 MySQL 8 中,你可以使用 mysqldump 工具来创建数据库的全量备份。要实现每天全量备份一次,并且保留最近7天的备份,你可以设置一个自动化的备份策略,通常通过编写一个 shell 脚本并使用 cron 定时任务来实现。

3、备份实现

3.1 创建备份脚本

创建一个名为 mysql_backup.sh 的脚本文件,内容如下:

复制代码
#!/bin/bash

# 设置数据库访问信息
DB_USER="root"
DB_PASSWORD="123456"
DB_HOST="localhost"

# 设置备份文件的存储路径
BACKUP_DIR="/root/mysql-back/data"

# 获取当前日期,格式为 YYYYMMDD
CURRENT_DATE=$(date +%Y%m%d)

# 创建备份文件的名称
BACKUP_FILE="$BACKUP_DIR/db_backup_$CURRENT_DATE.sql"

# 执行 mysqldump 命令,创建全量备份
mysqldump -h $DB_HOST -u $DB_USER -p$DB_PASSWORD --databases mytest1 mytest2 mytest3 > $BACKUP_FILE

# 检查备份是否成功
if [ $? -eq 0 ]; then
    echo "Backup successful: $BACKUP_FILE"
else
    echo "Backup failed"
    exit 1
fi

# 删除7天前的备份文件
find $BACKUP_DIR -name 'db_backup_*.sql' -type f -mtime +7 -exec rm {} \;
  • 修改脚本:请确保替换 your_username、your_password 和 /path/to/your/backup/directory 为你的数据库用户名、密码和备份文件存储路径。
  • 生成文件:每天一个文件,文件名示例:db_backup_20241026.sql。
    • 生成方式,如果文件已存在,直接覆盖。

3.2 使脚本可执行

在命令行中运行以下命令,使脚本具有可执行权限:

复制代码
chmod +x mysql_backup.sh

3.3 设置定时任务

使用 cron 来设置每天执行一次备份的定时任务。编辑当前用户的 cron 表:

复制代码
crontab -e

在打开的编辑器中,添加以下行来设置每天凌晨1点执行备份脚本:

复制代码
0 1 * * * /path/to/your/mysql_backup.sh

确保替换 /path/to/your/ 为你的脚本实际路径。

3.4 保存并退出

保存 cron 表的更改并退出编辑器。定时任务将自动设置并每天执行。

3.5 mysqldump备份

3.5.1 自定义数据库

复制代码
mysqldump -h [数据库服务器地址] -u [用户名] -p[密码] --databases [数据库] > [备份sql]
  • 数据库\]可以是多个,如: mysqldump -h [数据库服务器地址] -u [用户名] -p[密码] --databases mytest1 mytest2 mytest3 > mytest_backup.sql

    mysqldump -h [数据库服务器地址] -u [用户名] -p[密码] --all-databases > [备份sql]

4、还原

4.1 指定数据库方式

复制代码
mysql -h [数据库服务器地址] -u [用户名] -p[密码] [目标数据库名称] < [备份sql]

示例

复制代码
mysql -h localhost -u root -pAbc123@# mytest1  < mytest_backup.sql

4.2 不指定数据库方式

如果你的 SQL 文件包含创建数据库的语句,你也可以不指定目标数据库名称,直接导入 SQL 文件

复制代码
mysql -h [数据库服务器地址] -u [用户名] -p[密码]  < [备份sql]

示例

复制代码
mysql -h localhost -u root -p123456  < mytest_backup.sql
相关推荐
人工智能训练22 分钟前
如何在 Ubuntu 22.04 中安装 Docker 引擎和 Linux 版 Docker Desktop 桌面软件
linux·运维·服务器·数据库·ubuntu·docker·ai编程
胖头鱼的鱼缸(尹海文)43 分钟前
数据库管理-第386期 使用OCP部署OceanBase 4.4.1社区版集群(20251107)
数据库·oceanbase
Craaaayon1 小时前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
一 乐1 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
WarriorTan1 小时前
理解PostgreSQL中的数据块
数据库·postgresql
学好statistics和DS1 小时前
三个好思路:SQL并行化处理、混淆矩阵和特征交叉
数据库·sql·矩阵
唐僧洗头爱飘柔95272 小时前
【GORM(3)】Go的跨时代ORM框架!—— 数据库连接、配置参数;本文从0开始教会如何配置GORM的数据库
开发语言·数据库·后端·golang·gorm·orm框架·dsn
谅望者2 小时前
在 macOS 上使用 Homebrew 安装 MySQL 8.0 完整指南
数据库·sql·mysql
程序员卷卷狗3 小时前
MySQL 页结构与数据存储原理全解析》
数据库·mysql
hweiyu003 小时前
MySQL 从入门到精通(视频教程)
数据库·mysql