设置自动备份任务可以确保你的数据库定期备份,防止数据丢失。以下是如何使用 Bash 脚本和 Cron 任务在 Linux 系统上设置 MySQL 数据库的自动备份任务的详细步骤和代码示例。

1. 编写备份脚本

首先,我们需要编写一个备份脚本。这个脚本将包含执行备份的所有步骤。

1.1 创建并编辑备份脚本

创建一个名为 backup.sh 的脚本文件:

nano /path/to/backup.sh

添加以下内容到脚本文件中:

#!/bin/bash# 配置参数
DB_USER="root"
DB_PASSWORD="yourpassword"
BACKUP_DIR="/path/to/backups"
DATE=$(date +\%F_\%T)
FULL_BACKUP_IMAGE="$BACKUP_DIR/full_backup_$DATE.bak"
INCREMENTAL_BACKUP_IMAGE="$BACKUP_DIR/incremental_backup_$DATE.bak"# 检查是否需要完全备份
if [ ! -d "$BACKUP_DIR/full_backup" ] || [ -z "$(ls -A $BACKUP_DIR/full_backup)" ]; then# 执行完全备份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --backup-dir=$BACKUP_DIR/full_backup --backup-image=$FULL_BACKUP_IMAGE backup-to-image
else# 执行增量备份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --incremental --incremental-base=history:last_backup --backup-dir=$BACKUP_DIR/incremental_backup --backup-image=$INCREMENTAL_BACKUP_IMAGE backup-to-image
fi# 检查备份是否成功
if [ $? -eq 0 ]; thenecho "Backup successful: $FULL_BACKUP_IMAGE or $INCREMENTAL_BACKUP_IMAGE"
elseecho "Backup failed"exit 1
fiexit 0
1.2 给予脚本执行权限
chmod +x /path/to/backup.sh

2. 设置 Cron 任务

Cron 是一个 Unix 类操作系统的任务调度程序,用于在特定时间自动执行任务。我们将使用 Cron 来定时执行备份脚本。

2.1 编辑 Cron 表

打开 Cron 表进行编辑:

crontab -e
2.2 添加 Cron 任务

添加如下条目,例如每天凌晨 2 点执行备份:

0 2 * * * /path/to/backup.sh

这条命令的含义是每天凌晨 2 点执行 /path/to/backup.sh 脚本。Cron 表的格式如下:

* * * * * command
- - - - -
| | | | |
| | | | +----- day of week (0 - 7) (Sunday=0 or 7)
| | | +------- month (1 - 12)
| | +--------- day of month (1 - 31)
| +----------- hour (0 - 23)
+------------- minute (0 - 59)

3. 备份脚本细节

为了更详细地展示备份脚本的内容,这里进一步解释每一部分的作用。

3.1 配置参数

在脚本开头定义一些变量,包括数据库用户名、密码、备份目录和备份文件名:

DB_USER="root"
DB_PASSWORD="yourpassword"
BACKUP_DIR="/path/to/backups"
DATE=$(date +\%F_\%T)
FULL_BACKUP_IMAGE="$BACKUP_DIR/full_backup_$DATE.bak"
INCREMENTAL_BACKUP_IMAGE="$BACKUP_DIR/incremental_backup_$DATE.bak"
3.2 检查并执行备份

脚本检查是否存在一个完全备份目录以及是否为空。如果没有完全备份,脚本将执行完全备份。否则,它将执行增量备份:

if [ ! -d "$BACKUP_DIR/full_backup" ] || [ -z "$(ls -A $BACKUP_DIR/full_backup)" ]; then# 执行完全备份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --backup-dir=$BACKUP_DIR/full_backup --backup-image=$FULL_BACKUP_IMAGE backup-to-image
else# 执行增量备份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --incremental --incremental-base=history:last_backup --backup-dir=$BACKUP_DIR/incremental_backup --backup-image=$INCREMENTAL_BACKUP_IMAGE backup-to-image
fi
3.3 检查备份是否成功

脚本检查备份命令的退出状态码。如果备份成功,退出码为 0,脚本将显示成功消息,否则显示失败消息:

if [ $? -eq 0 ]; thenecho "Backup successful: $FULL_BACKUP_IMAGE or $INCREMENTAL_BACKUP_IMAGE"
elseecho "Backup failed"exit 1
fiexit 0

4. 验证自动备份任务

4.1 查看 Cron 任务

你可以使用以下命令查看当前用户的 Cron 任务:

crontab -l
4.2 检查备份文件

在第一次备份任务运行之后,检查备份目录 /path/to/backups,确保生成了备份文件。

5. 恢复备份

无论是自动备份还是手动备份,恢复步骤基本相同。

5.1 恢复完全备份
  1. 停止 MySQL 服务:

    sudo systemctl stop mysql
    
  2. 恢复完全备份:

    mysqlbackup --user=root --password=yourpassword --backup-dir=/path/to/backups/full_backup --backup-image=/path/to/backups/full_backup/full_backup_<date>.bak copy-back-and-apply-log
    
  3. 启动 MySQL 服务:

    sudo systemctl start mysql
    
5.2 恢复增量备份

恢复完全备份后,按顺序恢复每个增量备份:

  1. 停止 MySQL 服务:

    sudo systemctl stop mysql
    
  2. 恢复完全备份:

    mysqlbackup --user=root --password=yourpassword --backup-dir=/path/to/backups/full_backup --backup-image=/path/to/backups/full_backup/full_backup_<date>.bak copy-back-and-apply-log
    
  3. 恢复增量备份:

    mysqlbackup --user=root --password=yourpassword --incremental --backup-dir=/path/to/backups/incremental_backup --backup-image=/path/to/backups/incremental_backup/incremental_backup_<date>.bak apply-incremental-backup
    
  4. 启动 MySQL 服务:

    sudo systemctl start mysql
    

小结

通过编写备份脚本并使用 Cron 任务定时执行备份脚本,你可以实现 MySQL 数据库的自动备份。结合 MySQL Enterprise Backup 工具,可以灵活地进行完全备份和增量备份。定期检查备份文件并验证恢复过程是确保数据安全和可恢复性的关键。

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

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

相关文章

.NET 开发中全局数据存储的几种方式

文章目录 一、静态类与静态成员实现方式特点优缺点 二、应用程序配置系统1. appsettings.json (ASP.NET Core)使用方式2. 用户设置 (WinForms/WPF)特点 三、依赖注入容器ASP.NET Core 示例特点 四、内存缓存 (IMemoryCache)实现方式特点 五、分布式缓存 (IDistributedCache)实现…

人才争夺战关键期,AI如何赋能招聘效率倍增、精准选拔

数智化转型浪潮席卷全球的今天&#xff0c;人才作为企业核心竞争力的地位日益凸显。而在传统招聘流程&#xff0c;尤其是面试环节正面临效率瓶颈、体验短板等多项挑战&#xff0c;典型如&#xff1a; 耗时冗长的筛选与安排&#xff1b;难以避免的主观评价偏差&#xff1b;海量…

介绍下分布式ID的技术实现及应用场景

什么是分布式ID 分布式ID是指在分布式系统中生成的特定范围内唯一的标识符&#xff0c;如订单号、商品ID、链路追踪TraceID。 随着业务发展&#xff0c;对分布式ID的要求越来越高&#xff0c;其中最基本的要求如下 全局唯一&#xff1a;在任何节点、任何时间生成的ID都必须是…

【leetcode-字母异位词分组】

排序法 public List<List<String>> groupAnagrams(String[] strs) {//最终值List<List<String>> result new ArrayList<>();//排序法HashMap<String,List<String>> map new HashMap<>(); //遍历strfor(String str : strs){/…

langchain从入门到精通(九)——ChatGPT/Playground手动模拟记忆功能

1. 摘要缓冲混合记忆 摘要缓冲混合记忆中&#xff0c;所需的模块有&#xff1a; chat_message_history&#xff1a;存储历史消息列表。moving_summary_buffer&#xff1a;移除消息的汇总字符串。summary_llm&#xff1a;生成摘要的 LLM&#xff0c;接收 summary&#xff08;当…

docker单点安装Hadoop

1、Docker中拉取jdk8镜像 拉取镜像 docker pull openjdk:8-jdk 查看jdk docker run -it openjdk:8-jdk bash which java 2、安装ubuntu源 拉取镜像 docker pull ubuntu:22.04 保存 docker save -o ubuntu-22.04.tar.gz ubuntu:22.04 移动到自己想要的目录 mv /roo…

uniapp项目之小兔鲜儿小程序商城(二) 首页的实现:自定义导航栏,轮拨图,前台分类,热门推荐,猜你喜欢,下拉刷新,骨架屏

文章目录 零.首页最终效果一.自定义导航栏1.新建pages/index/components/CustomNavbar.vue首页子组件2.在首页pages/index/index.vue中引入3.隐藏默认导航栏修改标题颜色4.适配不同机型使用到了uniapp的一个api:获取屏幕边界到安全区域的距离在子组件中使用 二.轮拨图1.新建 sr…

RustDesk自建远程服务器

目录 服务端 环境linux 安装 开放端口 客户端配置 下载客户端 安装后配置网络 参考&#xff1a;RustDesk自建远程服务器_rustdesk自建服务器-CSDN博客 服务端 环境 linux 安装 下载 wget https://github.com/rustdesk/rustdesk-server/releases/download/1.1.8-2/r…

【Axure高保真原型】图片伸缩展示列表

今天和大家分享图片伸缩展示列表的3个原型案例&#xff0c;模版都是用中继器制作的&#xff0c;所以使用也很方便&#xff0c;在中继器表格里导入对应的图片&#xff0c;即可自动生成交互效果&#xff0c;具体效果可以点击下方视频观看或打开下方预览地址查看哦 【原型效果】 …

keil新建工程文件结构和每个文件的作用解析(标准库版本)

通过网盘分享的文件:STM32工程模板 链接:https://pan.baidu.com/s/1YPFgXu1kwuwsCVxrXFSjZg?pwd=1111 提取码: 1111 --来自百度网盘超级会员v5的分享 这个工程模版是来源于B站江科大的模版,每个人搭建工程文件结构不一样,仅供参考。 工程文件目录结构如图所示 1、DebugC…

【AI论文】Saffron-1:LLM安全保证的推理缩放范例

摘要&#xff1a;现有的安全保证研究主要集中在培训阶段的协调&#xff0c;以向LLM灌输安全行为。 然而&#xff0c;最近的研究表明这些方法容易受到各种越狱攻击。 同时&#xff0c;推理扩展显著提高了LLM推理能力&#xff0c;但在安全保证方面仍未得到探索。 为了解决这一差距…

LLM 支持的基于意图的分类 网络钓鱼电子邮件

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 抽象 网络钓鱼攻击仍然是现代网络安全的重大威胁&#xff0c;因为它们成功地欺骗了人类和旨在保护他们的防御机制。传统的检测系统主要关注用户在收件箱中看不到的电子邮件元数据。此外&#xff0c;这些…

C++新特性技术发展路径和时间

C 的新特性发展路径和时间线是一个持续演进的过程。以下是一个概览&#xff0c;涵盖了主要的 C 标准及其关键特性&#xff0c;以及它们发布的时间&#xff1a; C 标准版本及发布时间线: C98 (ISO/IEC 14882:1998): 第一个正式的 C 标准。 发布时间: 1998年关键特性: 标准模板库…

OpenAI 如何在激烈的AI人才争夺战中抢占先机?

在这个快速发展的人工智能时代&#xff0c;OpenAI 正处于一个至关重要的发展阶段。随着技术的不断进步&#xff0c;人工智能行业的竞争日益激烈。如何在这场巨大的竞争中立于不败之地&#xff0c;成为了每一个AI公司的核心挑战。就在近日&#xff0c;OpenAI 的新招聘主管华金・…

【Java学习笔记】Java绘图基础

Java绘图基础 一、Java 坐标体系 1. 像素的概念 计算机在屏幕上显示的内容都是由屏幕上的每一个像素组成的 例如&#xff0c;计算机显示器的分辨率是 800600&#xff0c;表示计算机屏幕上的每一行由 800 个点组成&#xff0c;共有 600 行&#xff0c;整个计算机屏幕共有 480…

资深Java工程师的面试题目(一)基础到高级概述

以下是几道面向资深Java工程师的面试题目&#xff0c;涵盖了从基础知识到高级概念及参考答案&#xff1a; 1. Java内存模型和垃圾回收 问题: 请解释一下Java的内存模型&#xff0c;并描述不同类型的内存区域。如何选择适合特定应用需求的垃圾收集器&#xff1f;请比较几种常…

Spring Retry:优雅地实现方法重试机制

前言 在实际的软件开发中&#xff0c;尤其是在涉及网络请求、数据库操作或外部服务调用的场景下&#xff0c;我们常常会遇到一些临时性故障&#xff08;Transient Failures&#xff09;&#xff0c;例如网络波动、数据库连接超时、第三方 API 暂时不可用等。面对这些问题&…

Mysql报错

1.权限问题 MySQL 认证协议不兼容问题解决方案 这个错误表明您的 MySQL 客户端与服务器要求的认证协议不兼容&#xff0c;通常发生在 MySQL 8.0 服务器与旧版客户端之间。 nested exception is org.apache.ibatis.exceptions.PersistenceException: Error querying database. …

小米汽车5月交付量超过28000台,与上月持平

6月1日&#xff0c;小米汽车公布5月交付数据&#xff0c;2025年5月&#xff0c;小米汽车交付量超过28000台&#xff0c;4月官方披露的交付数据也为28000台。 此外&#xff0c;小米汽车5月新增29家门店&#xff0c;全国82城已有298家门店&#xff1b;6月计划新增37家门店&#x…

严格一致性模型

SC 的第二点约束 :store 必须被 所有(包括自身)执行流 同时看到 ,但是不要求写操作“立即”对其他处理器可见&#xff1b;允许写操作延迟一会儿被其他核观察到。 而 严格一致性模型,包括1. store 必须被 所有(包括自身)执行流 同时看到2. 看到的时间 必须是 某个处理器完成写操…