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
# 指定脚本的解释器为Bashexport 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)
dobase=$(basename $file)# 使用basename命令从完整路径中提取文件名(不包含路径)NextNum=$(expr $NextNum + 1)# 将NextNum的值加1if [ $NextNum -eq $Counter ]then# 如果当前文件是索引文件中的最后一个文件echo $base skip! >> $LogFile# 则记录到日志文件中,表示跳过else# 如果不是最后一个文件dest=$BakDir/$base# 定义目标备份文件的完整路径if test -e $destthen# 如果目标备份文件已经存在echo $base exist! >> $LogFile# 则记录到日志文件中,表示文件已存在else# 如果目标文件不存在cp $BinDir/$base $BakDir# 将二进制日志文件从MySQL的日志目录复制到备份目录echo $base copying >> $LogFile# 记录到日志文件中,表示文件正在被复制fifi
done# 记录备份成功的消息到日志文件中,并附带当前日期和时间
echo $(date +"%Y年%m月%d日 %H:%M:%S") Backup success! >> $LogFile

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

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

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

相关文章

HTTP multipart/form-data 请求

序言 最近在写项目的过程中有一个需求是利用 HTTP 协议传输图片和视频,经过查询方法相应的方法发现使用 multipart/form-data 的方式,这是最常见处理二进制文件的表单编码类型。  学习了一下午,现在总结一下使用的方法和相关的知识点&#x…

Linux下redis环境的搭建

1.redis的下载 redis官网下载redis的linux压缩包,官网地址:Redis下载 网盘链接: 通过网盘分享的文件:redis-5.0.4.tar.gz 链接: https://pan.baidu.com/s/1cz3ifYrDcHWZXmT1fNzBrQ?pwdehgj 提取码: ehgj 2.redis安装与配置 将包上传到 /…

如何使用靜態IP代理?【詳細教程】

靜態IP地址是手動分配給設備或伺服器的固定不變的 IP。與動態 IP 地址不同,動態 IP 地址由 DHCP 伺服器自動分配,並且會隨時間而變化。​​​​​​​ 如何獲取和設置靜態IP地址 一、檢查是否需要靜態IP? 在配置靜態 IP 之前,請…

监控组态软件的构成与功能

监控组态软件的构成包括系统开发环境、图形界面系统、实时数据库系统等。其功能包括数据采集与控制、人机交互界面、数据处理与存储等。 监控组态软件的构成: 系统开发环境:这是自动化工程设计工程师为实施其控制方案,在组态软件的支持下进行…

Java 基础之 XQuery:强大的 XML 查询语言

一、什么是 XQuery XQuery 是一种函数式语言,专门用于检索以 XML 格式存储的信息。它负责从 XML 文档中查找和提取元素及属性,在网络服务中有着广泛的应用,比如提取信息、生成摘要报告、进行数据转换等。 XQuery 是 W3C 设计的一种针对于 X…

day09性能测试(1)——纯理论

document.querySelector(video).playbackRate 2.5 //可以写任何数字 【没有所谓的运气🍬,只有绝对的努力✊】 目录 1、性能测试概念 2、功能测试 vs 性能测试 3、小结(习题) 4、性能测试的策略 4.1 基准测试 4.2 负载测试 …

docker-3.docker权限问题

docker权限,每次开机都要重新sudo 目录 1.简介2.解决办法1:当前用户添加到docker用户组(这个方法还是缺权限??)3.解决办法2:临时更改Docker socket文件权限1.简介 Ubuntu下Docker提示permission denied (权限不足)解决办法 安装docker后,执行docker ps命令时提示 perm…

easyExcel实现表头批注

背景&#xff1a; 网上大部分都不能直接使用&#xff0c;为此总结一个方便入手且可用的工具&#xff0c;用自定义注解实现 依赖包&#xff1a; <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>…

内部类和Object类

匿名对象 格式&#xff1a; 匿名对象只可以调用一次成员 &#xff1a; 1. 调用一次成员变量 &#xff1a; new 类名(实参).成员变量名&#xff1b; 2.调用一次成员方法&#xff1a; new 类名(实参).成员方法名(实参)&#xff1b; 匿名对象存在的必要&#xff1a;为了提高…

Python的3D可视化库vedo 1-3 (visual模块)网格对象的线和面、图片的属性

文章目录 4 MeshVisual4.1 线条4.1.1 线宽和颜色4.1.2 线条渲染为管 4.2 曲面4.2.1 物体展示为实心或框架4.2.2 曲面插值4.2.3 面的剔除 4.3 纹理4.4 相机跟随 5 ImageVisual5.1 图片属性5.1.1 占用内存大小5.1.2 颜色标量范围 5.2 渲染属性5.2.1 透明度5.2.2 亮度5.2.3 对比度…

19 设计模式之享元模式(电影院座位预定案例)

一、享元模式的定义 享元模式是一种结构型设计模式&#xff0c;它通过共享对象来支持大量细粒度的对象&#xff0c;减少内存消耗。享元模式的核心思想是&#xff1a;将对象分为共享部分和非共享部分&#xff0c;只有共享部分是被多个对象共享的&#xff0c;而非共享部分则是每个…

使用redis 的stream 做消息中间件 多线程消费消息

1.redis stream 特点 1.支持消息持久化 2.消费者组模式 3.消息确认机制 4. 消息重试机制 5. 死信队列2. 消息生产者服务 2.1 如下代码Service Slf4j public class StreamMessageProducer {Autowiredprivate StringRedisTemplate redisTemplate;private static final String S…

Python100道练习题

Python100道练习题 BIlibili 1、两数之和 num1 20 num2 22result num1 num2print(result)2、一百以内的偶数 list1 []for i in range(1,100):if i % 2 0:list1.append(i) print(list1)3、一百以内的奇数 # 方法一 list1 [] for i in range(1,100):if i % 2 ! 0:lis…

Java转C之并发和多线程

提纲&#xff1a; 概念介绍与对比概述 简述Java与C在并发和多线程方面的核心区别解释C11标准、POSIX、C11 <threads.h>、Pthread等名词 Java多线程与并发回顾 线程、Runnable、ExecutorService概念说明同步关键字与工具类含义 C并发基础 没有Java式的内置线程类&#xf…

Ubuntu系统本地化搭建Maxakb+Ollama

安装docker 最详细的ubuntu 安装 docker教程-腾讯云开发者社区-腾讯云 安装Ollama Ollama官网 执行命令&#xff1a; curl -fsSL https://ollama.com/install.sh | sh安装完成后下载模型 执行命令&#xff1a; ollama run llama3.3:70b安装MaxKb 执行命令&#xff1a; d…

基于JAVA的旅游网站系统设计

摘要 随着信息技术和网络技术的迅速发展&#xff0c;人们的生活质量和观念也在发生着改变&#xff0c;各地争相发展旅游业&#xff0c;传统的 旅游社已经无法满足人们的需求&#xff0c;旅游网站将突破传统在时间和地域的限制&#xff0c;成为方便、快捷、安全、可靠的旅游 方…

【Flux.jl】 卷积神经网络

Flux.jl 是包含卷积神经网络的, 但是官方API文件中没有给出一个完整的程序框架, 只是对所需神经元给了局部解释, 此外对 model-zoo 模型动物园中的案例没有及时跟着 Flux.jl 的版本更新, 也无法运行出来结果。 因此本文搭建了一个完整可训练的卷积神经网络。 Conv 卷积算子…

H5游戏出海如何获得更多增长机会?

海外H5小游戏的崛起给了国内众多中小厂商出海发展的机会&#xff0c;开发者如何在海外市场获得更多的增长机会&#xff1f;#APP出海# H5游戏如何在海外获得核心用户&#xff1f; HTML5游戏的开发与运营者们首先可以利用量多质高的HTML5游戏&#xff0c;维持海外用户粘性&…

Next.js系统性教学:深入理解和应用组件组合模式

更多有关Next.js教程&#xff0c;请查阅&#xff1a; 【目录】Next.js 独立开发系列教程-CSDN博客 目录 更多有关Next.js教程&#xff0c;请查阅&#xff1a; 1. 什么是组件组合模式&#xff1f; 1.1 组件组合模式概述 1.2 组件组合模式的优势 2. Next.js 中的组件组合模式…

国际荐酒师Peter助力第六届地博会,推动地理标志产品国际化发展

国际荐酒师Peter Lisicky助力第六届知交会暨地博会&#xff0c;推动地理标志产品国际化发展 第六届粤港澳大湾区知识产权交易博览会暨国际地理标志产品交易博览会于2024年12月9日至11日在中新广州知识城盛大举行&#xff0c;吸引了全球众多行业专家、企业代表及相关机构齐聚一…