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 ]; thenecho "Backup successful: $BACKUP_FILE"
elseecho "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

3.5.2 全部数据库

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/57984.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 串口通信教程

串口通信&#xff08;Serial Communication&#xff09;是一种用于设备之间数据传输的常见方法&#xff0c;通常用于与外部硬件设备&#xff08;如传感器、机器人、微控制器&#xff09;进行通信。在 C# 中&#xff0c;System.IO.Ports 命名空间提供了与串口设备交互的功能&…

2024Flutter面试题

1.Dart是值传递还是引用传递&#xff1f; dart是值传递。 每次调用函数&#xff0c;传递过去的都是对象的内存地址&#xff0c;而不是这个对象的赋值。 2.简述Dart语音特性 在Dart中&#xff0c;一切都是对象&#xff0c;所有的对象都是继承自Object Dart是强类型语言&#…

mono源码交叉编译 linux arm arm64全过程

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码指引&#xff1a;github源…

GPT-4o 和 GPT-4 Turbo 模型之间的对比

GPT-4o 和 GPT-4 Turbo 之间的对比 备注 要弄 AI &#xff0c;不同模型之间的对比就比较重要。 GPT-4o 是 GPT-4 Turbo 的升级版本&#xff0c;能够提供比 GPT-4 Turbo 更多的内容和信息&#xff0c;但成功相对来说更高一些。 第三方引用 在 2024 年 5 月 13 日&#xff0…

8.MySQL复合查询

目录 复合查询基本查询回顾多表查询 - 笛卡尔积自连接子查询单行子查询多行子查询多列子查询在from中使用子查询 合并查询unionunion all 表的内连和外连内连接外连接左外连接右外连接 复合查询 前面我们讲解的mysql表的查询都是对一张表进行查询&#xff0c;在实际开发中这远远…

HTML+JavaScript案例分享: 打造经典俄罗斯方块,详解实现全过程

在本文中,我们将深入探讨如何使用 JavaScript 实现经典的俄罗斯方块游戏。俄罗斯方块是一款广为人知的益智游戏,通过操纵各种形状的方块,使其在游戏区域内排列整齐,以消除完整的行来获得分数。 效果图如下: 一、游戏界面与布局 我们首先使用 HTML 和 CSS 来创建游戏的界面…

java智能物流管理系统源码(springboot)

项目简介 智能物流管理系统实现了以下功能&#xff1a; 智能物流管理系统的主要使用者分为管理员&#xff0c;顾客&#xff0c;员工&#xff0c;店主。功能有个人中心&#xff0c;顾客管理&#xff0c;员工管理&#xff0c;店主管理&#xff0c;门店信息管理&#xff0c;门店…

gin入门教程(4):路由与处理器

路由与处理器 在 Gin 框架中&#xff0c;路由和处理器是核心组成部分&#xff0c;负责将 HTTP 请求映射到相应的处理逻辑。 1. 定义路由 在 cmd/main.go 中&#xff0c;您可以定义不同的路由&#xff0c;例如&#xff1a; r.GET("/ping", func(c *gin.Context) {…

.NET 8 Web API从基础到提高全面示例

.NET 8 Web API从基础到提高全面示例 概述&#xff1a;1. 设置 .NET 8 Web API 项目概念使用 .NET CLI 创建新的 Web API 项目。这设置了一个基本的项目结构&#xff0c;包括启动和 WeatherForecast 控制器作为示例。Program.cs代码示例dotnet new webapi -n MyWebApi2. Prog…

查看Chrome安装路

谷歌Google浏览器查看安装路径&#xff0c;浏览器Google Chrome浏览器查看安装路径 chrome://version/ 来源&#xff1a;笔记云

如何训练SDXL,finetune,Docker,实战教程

启动容器: docker run -it --rm --gpus all --net host --shm-size=16g -v /root/xiedong:/root/xiedong kevinchina/deeplearning:pytorch2.3.0-cuda12.1-cudnn8-devel-xformers-lora-train bash启动webui: cd /workspace/lora-scriptspython gui.py --host "0.0.0.0…

自动化桌面通知:使用Plyer库实现工作提醒

1. 引言 在日常工作中&#xff0c;我们经常需要设置各种提醒来帮助自己记住重要的事情。利用Python编程语言和plyer库&#xff0c;我们可以非常方便地创建一个自动化桌面通知系统&#xff0c;它可以在特定时间或周期性地向用户展示通知消息。 2. 安装Plyer库 在开始编码之前…

idea安装visualVm插件

idea 安装visualVM插件用于分析java程序&#xff0c; 1.在插件市场安装visualvm launcher 2.安装成功后&#xff0c;重启idea&#xff0c;此时启动按钮旁边有这两个按钮 3.需要在这里配置插件的visualvm位置 4.配置完后&#xff0c;点击启动

10.25学习

1.程序链接库 程序链接库&#xff08;Library&#xff09;&#xff0c;通常简称为库&#xff0c;是程序设计中一种常用的代码组织方式。它包含了一组预先编写好的代码&#xff0c;这些代码可以被多个不同的程序调用&#xff0c;以实现特定的功能。使用链接库的主要目的包括&am…

已解决 django.db.utils.OperationalError: (1051, “Unknown table

报错信息&#xff1a; django.db.utils.OperationalError: (1051, "Unknown table bjybolg.tool_submission")python manage.py migrate --fake 命令用于告诉 Django 假装已经应用某个迁移&#xff0c;而不实际执行该迁移的操作。这通常在以下情况下非常有用&#x…

Layout 布局组件快速搭建

文章目录 设置主题样式变量封装公共布局组件封装 Logo 组件封装 Menu 菜单组件封装 Breadcrumb 面包屑组件封装 TabBar 标签栏组件封装 Main 内容区组件封装 Footer 底部组件封装 Theme 主题组件 经典布局水平布局响应式布局搭建 Layout 布局组件添加 Layout 路由配置启动项目 …

Linux: Shell编程入门

Shell 编程入门 1 ) Shell 概念 shell 是 在英语中 壳, 外壳的意思可以把它想象成嵌入在linux这样的操作系统里面的一个微型的编程语言不像C语言, C 或 Java 等编程语言那么完整&#xff0c;它可以帮我们完成很多自动化任务例如保存数据监测系统的负载等等&#xff0c;我们同样…

windows手动配置IP地址与DNS服务器以及netsh端口转发

在Windows系统中&#xff0c;配置主机的IP地址、子网掩码和网关地址可以通过以下步骤手动设置。这在某些情况下是必要的&#xff0c;例如当你需要确保网络接口使用特定的IP地址或网关时。 手动设置IP地址、子网掩码和网关地址的步骤 打开“网络和Internet设置”&#xff1a; 右…

【ArcGIS Pro实操第8期】绘制WRF三层嵌套区域

【ArcGIS Pro实操第8期】绘制WRF三层嵌套区域 数据准备ArcGIS Pro绘制WRF三层嵌套区域Map-绘制三层嵌套区域更改ArcMap地图的默认显示方向指定数据框范围 Map绘制研究区Layout-布局出图 参考 本博客基于ArcGIS Pro绘制WRF三层嵌套区域&#xff0c;具体实现图形参考下图&#xf…

从零开始学五笔(七):折区字根

讲解格式&#xff1a; 先介绍按键的区位号、口诀内容、口诀说明然后列每个字根能组成什么汉字&#xff0c;难拆字将用中括号标出 ‍ N 键 区位号&#xff1a;51 口诀&#xff1a;已半巳满不出己&#xff0c;左框折尸心和羽 说明&#xff1a; 已半巳满不出己&#xff1a;指…