当前位置: 首页 > article >正文

MySQL生产环境备份脚本

全量备份脚本,其中BakDir,ZlbakDir,LogFile需要自己创建

#!/bin/bash
export LANG=en_US.UTF-8

# 指定备份目录
BakDir=/root/beifen/data/mysqlbak/data/allbak
# 指定增量备份目录
ZlbakDir=/root/beifen/data/mysqlbak/data/zlbak
# 备份日志位置
LogFile=/root/beifen/data/mysqlbak/log/bak.log

# 获取当前时间
CurrentDate=$(date +%Y-%m-%d-%H-%M-%S)
# 脚本执行时间
Begin=$(date +"%Y年%m月%d日 %H:%M:%S")
# 要备份的数据库
Database=a

# 进入全备目录
cd $BakDir || exit 1  # 如果目录不存在或无法进入,则退出脚本

# 存储即将生成的SQL备份文件名称
DumpFile=$Database-$CurrentDate.sql
# 存储压缩后的名称
GZDumpFile=$Database-$CurrentDate.tar.gz

# 使用mysqldump进行备份,--flush-logs会刷新日志,--delete-master-logs会删除旧的二进制日志(注意:这通常在生产环境中使用时需要谨慎),--single-transaction用InnoDB表的一致性备份。
mysqldump -u root -plmx $Database --flush-logs --delete-master-logs --single-transaction > $BakDir/$DumpFile

 
# 用tar命令将SQL备份文件压缩成tar.gz格式
tar -czvf "$GZDumpFile" "$DumpFile"
rm "$DumpFile"

# 统计当前目录下.tar.gz文件的数量
count=$(ls -l *.tar.gz 2>/dev/null | wc -l)
if [ $count -ge 2 ]; then
  # 删除最旧的.tar.gz文件
  file=$(ls -lt *.tar.gz | head -n 1 | awk '{print $9}')
  rm -f "$file"
fi

# 获取脚本结束时的日期和时间
Last=$(date +"%Y年%m月%d日 %H:%M:%S")

# 将备份的开始时间、结束时间和成功生成的压缩文件名追加到日志文件中
echo "开始:$Begin 结束:$Last $GZDumpFile success" >> "$LogFile"

# 进入增量备份目录,这里假设您只想清空目录(注意:这可能会删除重要文件)
cd $ZlbakDir || exit 1
rm -f *

# 如果需要保留某些文件(如binlog),请修改上面的rm命令以排除这些文件。

成功后会在目录里看到一个tar.gz包,解压之后就可以查看sql文件了
在这里插入图片描述
增量备份脚本
其中BakDir,LogFile需要自己创建,BinDir和BinFile需要自己寻找,如果不知道在那的话登录MySQL输入以下两条命令

MySQL 会自动管理二进制日志索引文件,其名称通常与二进制日志文件的基本名称相同,但扩展名为 .index。在您的配置中,由于 log-bin=mysql-bin,二进制日志索引文件通常会被命名为 mysql-bin.index

#!/bin/bash
# 指定脚本的解释器为Bash

export LANG=en_US.UTF-8
# 设置环境变量LANG为en_US.UTF-8,确保脚本在处理文本时使用UTF-8编码

BakDir=/root/beifen/data/mysqlbak/data/zlbak
# 定义备份目录的路径

BinDir=/usr/local/mysql/data
# 定义MySQL二进制日志文件的目录路径

LogFile=/root/beifen/data/mysqlbak/log/binlog.log
# 定义日志文件的路径,用于记录备份过程中的信息

BinFile=/usr/local/mysql/data/mysql-bin.index
# 定义包含二进制日志文件列表的索引文件的路径

mysqladmin  -u root -plmx flush-logs
# 使用mysqladmin命令刷新MySQL的日志,包括二进制日志。

Counter=$(wc -l $BinFile | awk '{print $1}')
# 计算索引文件($BinFile)中的行数,即二进制日志文件的数量,并将结果存储在变量Counter中

NextNum=0
# 初始化NextNum变量为0,用于在后续循环中计数

# 这个for循环用于遍历索引文件($BinFile)中的每一行(每个文件路径)
for file in $(cat $BinFile)
do
    base=$(basename $file)
    # 使用basename命令从完整路径中提取文件名(不包含路径)

    NextNum=$(expr $NextNum + 1)
    # 将NextNum的值加1

    if [ $NextNum -eq $Counter ]
    then
        # 如果当前文件是索引文件中的最后一个文件
        echo $base skip! >> $LogFile
        # 则记录到日志文件中,表示跳过
    else
        # 如果不是最后一个文件
        dest=$BakDir/$base
        # 定义目标备份文件的完整路径

        if test -e $dest
        then
            # 如果目标备份文件已经存在
            echo $base exist! >> $LogFile
            # 则记录到日志文件中,表示文件已存在
        else
            # 如果目标文件不存在
            cp $BinDir/$base $BakDir
            # 将二进制日志文件从MySQL的日志目录复制到备份目录

            echo $base copying >> $LogFile
            # 记录到日志文件中,表示文件正在被复制
        fi
    fi
done

# 记录备份成功的消息到日志文件中,并附带当前日期和时间
echo $(date +"%Y年%m月%d日 %H:%M:%S") Backup success! >> $LogFile

成功后如下
在这里插入图片描述


http://www.kler.cn/a/429767.html

相关文章:

  • 反转链表题目
  • JAVA安全编码规范
  • 后端技术选型 sa-token校验学习 中 文档学习
  • OStree技术简介
  • C#版 软件开发6大原则与23种设计模式
  • Unreal Engine 5 (UE5) Metahuman 的头部材质
  • 【JavaWeb后端学习笔记】登录校验(JWT令牌技术、Interceptor拦截器、Filter过滤器)
  • 学生信息管理系统(简化版)数据库部分
  • 基于公网的无线全双工内部通话系统在演出行业可以用吗?
  • 纯虚函数和抽象类在面向对象编程中的意义
  • 【机器学习】基础知识:SSR-残差平方和(Sum of Squared Residuals)
  • 能源变革,分布式光伏与储能协调控制
  • socket UDP 环路回显的服务端
  • OPC UA 客户端开发工具,模拟器,可视化GUI
  • HarmonyOS-高级(一)
  • 使用 `typing_extensions.TypeAlias` 简化类型定义:初学者指南
  • 入门网络安全工程师要学习哪些内容【2025年寒假最新学习计划】
  • 在2023idea中如何创建SpringBoot
  • 嵌入式蓝桥杯学习6 定时中断按键(短按 长按 双击)
  • Spring Boot前沿技术集成:驱动招聘信息管理系统高效运转
  • Rust之抽空学习系列(一)—— Hello World
  • Java的Mvc整合Swagger的knife4框架
  • 12.09 C++作业2
  • 【Java计算机毕业设计】Springboot+vue动物保护协会管理系统【源代码+数据库+LW文档+开题报告+答辩稿+部署教程+代码讲解】
  • 如何设置合理的爬取频率避免被网站封锁?
  • 【Python】【Conda 】Conda vs venv:Python开发者的虚拟环境选择指南