xtrabackup脚本
xtrabackup是MySQL的一种物理备份工具,相对于mysqldump,备份和还原速度更快 , 我写了一份可以进行备份 + 还原的脚本
#!bin/bash
all_bak_path="/opt/my_bak/xbak" # 主备目录
add_bak_path="/opt/my_bak/add" # 增量备份目录
mysql_data_path="/data/mysql/data" # 数据库数据路径
mysql_name="mysqld" # 数据库名称
mysql_cnf="/etc/my.cnf" # MySQL 配置文件
userName="root" # 数据库用户名称
userPasswd="root" # 数据库用户密码
# 获取mysql.sock文件路径
# sock_path=$(find / -name mysql.sock) # 第一次获取时使用
sock_path="/usr/local/mysql/mysql.sock"
mysql_port="3306"
innobackupex_options="
--defaults-file=${mysql_cnf} \
--socket=${sock_path} \
--user=${userName} --password=${userPasswd} \
--port=${mysql_port}"
# 0.创建全量备份和增来那个备份路径
create_path(){
if [ ! -d ${all_bak_path} ] ; then
mkdir -p ${all_bak_path}
echo "创建/opt/my_bak/xbak/目录完成"
fi
if [ ! -d ${add_bak_path} ] ; then
mkdir -p ${add_bak_path}
echo "创建/opt/my_bak/add/目录完成"
fi
}
# 1.安装xtrabackup
ins_xtra(){
ins_app="libev-4.03-3.el6.x86_64.rpm percona-xtrabackup-24-2.4.29-1.el7.x86_64.rpm"
yum -y install $ins_app
if [ $? -ne 0 ]; then
echo "安装xtrabackup失败"
exit 1
fi
echo "安装xtrabackup完成"
data_dir=$(cat ${mysql_cnf} | grep datadir)
if [ -z "$data_dir" ]; then
cat >> ${mysql_cnf} <<EOF
datadir=${mysql_data_path}/ # 选择备份的数据库目录
EOF
systemctl restart ${mysql_name}
if [ $? -ne 0 ]; then
echo "重启mysql失败"
exit 1
fi
echo -e "修改${mysql_cnf}文件完成"
fi
}
# 2.对数据库进行全量备份
all_backup(){
innobackupex ${innobackupex_options} ${all_bak_path}
}
# 3.对数据进行增量备份
add_backup(){
# 检测是否有全量备份
if [ -z "$(find $all_bak_path -maxdepth 1 -type d)" ]; then
echo "没有全量备份,需先全量备份"
exit 1
fi
# 执行增量备份部分语句
add_half="innobackupex ${innobackupex_options} \
--incremental "${add_bak_path}" "
#最新的全量备份
new_all_backup_path=$(find ${all_bak_path}/*_* -maxdepth 0 -type d | sort -r | head -1)
#没有更新的话,上一次目录路径选择全量目录
if [ -z "$(find $add_bak_path -mindepth 1 -maxdepth 1)" ]; then
$add_half --incremental-basedir="${new_all_backup_path}"
echo "增量执行完成,在全量备份后备份"
else
# 获取所有增量备份
new_add_backup_path=($(find ${add_bak_path}/*_* -maxdepth 0 -type d | sort | cut -d ":" -f 1))
# 获取全量备份文件名
tmp_all_path=$(echo $new_all_backup_path | cut -d "/" -f 5)
# 将文件名格式化为数字格式
all_time=$(echo "${tmp_all_path//[-_]}/" | cut -d "/" -f 1)
# 获取增量备份数量
add_length=${#new_add_backup_path[@]}
# 获取全量备份以后得增量备份
for i in ${new_add_backup_path[@]} ; do # 遍历
tmp_add_path=$(echo $i | cut -d "/" -f 5) # 获取文件名
add_time=$(echo "${tmp_add_path//[-_]}/" | cut -d "/" -f 1) # 将文件名格式化为数字格式
if [ $all_time -le $add_time ] ; then # 判断增量备份名称是否相对于全量备份日期更新
$add_half --incremental-basedir="${new_add_backup_path[add_length-1]}"
echo -e "增量执行完成,在上一次增量备份后备份,上一次备份位置${new_add_backup_path[add_length-1]}"
break
else
$add_half --incremental-basedir="${new_all_backup_path}"
echo "增量执行完成,在全量备份后备份"
break
fi
done
fi
}
# 4.对全量备份进行合并
merge_backup(){
#最新的全量备份
new_all_backup_path=$(find ${all_bak_path}/*_* -maxdepth 0 -type d | sort -r | head -1)
# 倒序获取所有增量备份
new_add_backup_path=($(find ${add_bak_path}/*_* -maxdepth 0 -type d | sort | cut -d ":" -f 1))
# 获取全量备份文件名
tmp_all_path=$(echo $new_all_backup_path | cut -d "/" -f 5)
# 将文件名格式化为数字格式
all_time=$(echo "${tmp_all_path//[-_]}/" | cut -d "/" -f 1)
# 获取增量备份数量
add_length=${#new_add_backup_path[@]}
# 执行合并部分语句
apply_half="innobackupex --apply-log"
echo "准备全量备份"
${apply_half} --redo-only $new_all_backup_path
if [ $? -eq 0 ] ; then
echo -e "准备全量备份完成,位置为${new_all_backup_path}"
else
echo "准备全量备份报错,位置为${new_all_backup_path}"
exit 1
fi
# 将增量备份脚本从后向前进行合并
if [ -n $new_add_backup_path ] ; then
# 获取全量备份以后得增量备份
for i in ${new_add_backup_path[@]} ; do # 遍历
tmp_add_path=$(echo $i | cut -d "/" -f 5) # 获取文件名
add_time=$(echo "${tmp_add_path//[-_]}/" | cut -d "/" -f 1) # 将文件名格式化为数字格式
if [ $all_time -le $add_time ] ; then # 判断增量备份名称是否相对于全量备份日期更新
if [ $i == ${new_add_backup_path[add_length - 1]} ] ; then
$apply_half $new_all_backup_path --incremental-dir=${new_add_backup_path[add_length - 1]}
if [ $? -eq 0 ] ; then
echo -e "最后一次合并完成,位置为${i}"
else
echo "最后一次合并报错,位置为${i}"
exit 1
fi
else
$apply_half --redo-only $new_all_backup_path --incremental-dir=$i
if [ $? -eq 0 ] ; then
echo -e "增量合并至全量完成,位置为${i}"
else
echo "增量合并至全量报错,位置为${i}"
echo -e "语句为: $apply_half --redo-only $new_all_backup_path --incremental-dir=${i}"
exit 1
fi
fi
fi
done
else
echo "没有增量备份"
fi
echo "最后一次准备全量备份"
${apply_half} $new_all_backup_path
if [ $? -eq 0 ] ; then
echo -e "准备全量备份完成,位置为${new_all_backup_path}"
else
echo "准备全量备份报错,位置为${new_all_backup_path}"
exit 1
fi
}
# 5.对数据库进行还原
db_restore(){
#最新的全量备份
new_all_backup_path=$(find ${all_bak_path}/*_* -maxdepth 0 -type d | sort -r | head -1)
innobackupex --copy-back ${new_all_backup_path}
echo "还原数据完成"
chown -R mysql.mysql ${mysql_data_path}
echo "修改mysql数据库权限完成"
systemctl restart ${mysql_name}
echo "重启数据库完成"
echo "数据库连接测试: "
mysql -u${userName} -p${userPasswd} -e "show databases"
mysql -u${userName} -p${userPasswd} -e "select * from test.testlog"
}
options=("全量备份" "增量备份" "还原数据" "安装xtrabackup" "点击任意键退出")
create_path
select i in ${options[@]} ;do
case $i in
${options[0]})
all_backup
;;
${options[1]})
add_backup
;;
${options[2]})
merge_backup
db_restore
;;
${options[3]})
ins_xtra
;;
*)
echo "退出"
break 2
;;
esac
done
``
xtrabackup脚本的更多相关文章
- 「转」xtrabackup新版详细说明
声明:本文由我的同事@fiona514编写,是我看过的最用心的中文说明介绍,强烈推荐大家学习使用. Percona Xtrabackup 2.4.1 编译及软件依赖 centos5,6 需要升级cma ...
- XtraBackup 原理与安装
简介 XtraBackup(PXB) 工具是 Percona 公司用 perl 语言开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server ...
- mysql和mariadb备份工具xtrabackup和mariabackup(mariadb上版本必须用这个)
简介 xtraBackup(PXB) 工具是 Percona 公司用 perl 语言开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server ...
- mysql 开发进阶篇系列 44 物理备份与恢复( 热备份xtrabackup 工具介绍)
一.概述 物理备份和恢复又分为冷备份和热备份.与逻辑备份相比,它最大优点是备份和恢复的速度更快.因为物理备份的原理都是基于文件的cp. 1.1 冷备份 冷备份就是停掉数据库服务.这种物理备份一般很少使 ...
- Xtrabackup的安装与使用
Xtrabackup的安装与使用 1. XtraBackup 简介 XtraBackup(PXB) 工具是 Percona 公司用 perl 语言开发的一个用于 MySQL 数据库物理热备的备份工具, ...
- MySQL数据库之xtrabackup物理备份(一)
前言:说到数据库备份,我们知道可以用来对数据库进行备份的工具有mysqldump.mydumer.mysqlpump等等,实际工作中,机器上的数据库不大的话,都是用mysqldump工具来备份,这些备 ...
- MySQL 使用XtraBackup的shell脚本介绍
mysql_backup.sh是关于MySQL的一个使用XtraBackup做备份的shell脚本,实现了简单的完整备份和增量备份.以及邮件发送备份信息等功能.功能目前还比较简单,后续将继续完善和增加 ...
- centos shell编程6一些工作中实践脚本 nagios监控脚本 自定义zabbix脚本 mysql备份脚本 zabbix错误日志 直接送给bc做计算 gzip innobackupex/Xtrabackup 第四十节课
centos shell编程6一些工作中实践脚本 nagios监控脚本 自定义zabbix脚本 mysql备份脚本 zabbix错误日志 直接送给bc做计算 gzip innobacku ...
- Xtrabackup每周增量备份脚本程序
Xtrabackup每周增量备份脚本程序(含附件) 程序描述 本程序是一个对percona xtrabackup使用的脚本,它完成了MySQL每周的备份. 程序结构 此程序包含了4个目录(bin. ...
- MySQL XtraBackup自动恢复脚本
#!/bin/sh ################## #author:rrhelei@126.com# ################## #xtrabackup2.1.8 # 使用方法: ...
随机推荐
- GitHub Star 数量前 13 的自托管项目清单
一个多月前,我们撰写并发布了这篇文章<终极自托管解决方案指南>.在那篇文章里我们深入探讨了云端服务与自托管方案的对比.自托管的潜在挑战.如何选择适合自托管解决方案,并深入介绍了五款涵盖不同 ...
- Nuxt Kit 组件管理:注册与自动导入
title: Nuxt Kit 组件管理:注册与自动导入 date: 2024/9/15 updated: 2024/9/15 author: cmdragon excerpt: Nuxt Kit 为 ...
- IDEA 换了电脑,如何导入和导出配置?
前言 我们在使用IDEA开发时,经常会设置各种各样的配置,时间一长,就会有很多个性化的东西.用起来也越来越顺手. 不过这里可能会有个问题,那就是哪一天我们要换个电脑了,或者想安装新版本的IDEA时 ...
- BFS 颜色填涂———洛谷p1162
填涂颜色 题目描述 由数字 \(0\) 组成的方阵中,有一任意形状的由数字 \(1\) 构成的闭合圈.现要求把闭合圈内的所有空间都填写成 \(2\).例如:\(6\times 6\) 的方阵(\(n= ...
- 控制请求并发数量:p-limit 源码解读
p-limit 是一个控制请求并发数量的库,他的整体代码不多,思路挺好的,很有学习价值: 举例 当我们同时发起多个请求时,一般是这样做的 Promise.all([ requestFn1, reque ...
- 暑假集训CSP提高模拟 16
\[暑假集训CSP提高模拟 \lim_{x\rightarrow\infty}\frac{8f_{x}}{f_{x+1}}\times(\sqrt{5}+1),\ \forall f_{x}=f_{x ...
- kali系统安装和CVE-2017-12615测试
1 安装kali系统 1.1 下载VMware压缩包 kali-linux-2022.1 默认的用户和密码是kali 1.2 初始化系统 sudo apt update -y #kali sudo a ...
- 自己动手,通过源码找回 Ant-Design-Blaozr 中 Tree 组件的搜索筛选效果
最近更新一个Blazor server的项目,顺带把用到的Ant-Design-Blazor 升级到了最新的 0.14.4,结果发现之前在 0.8.4 版本中 Tree 组件的搜索显示效果变了,从仅显 ...
- Vue 组件如何进行传值的?
1 父子传值 在子组件标签设置属性,在子组件内使用 props 接收属性值 : 2. 子父传值 在子组件中使用 emit 自定义事件,在子组件标签注册自定义事件 ,接收参数 : 3. vuex 状态管 ...
- Nuxt.js 应用中的 modules:done 事件钩子详解
title: Nuxt.js 应用中的 modules:done 事件钩子详解 date: 2024/10/16 updated: 2024/10/16 author: cmdragon excerp ...