一、背景:

由于阿里云RDS生产库每天都需要备份且拷贝到自建读库,而如果使用阿里云的自动拷贝到只读实例, 费用太高, 故采用自编写同步脚本方法实现。

二、前提:

1). 已开通阿里云RDS, 且开启定期备份功能。(备份功能生成备份文件供下载)

2). 已在备份的目标服务器上安装mysql数据库。

3). 备份目标服务器已安装数据恢复工具Percona XtraBackup,您可以从Percona XtraBackup官网下载安装。

  • MySQL 5.6及之前的版本需要安装 Percona XtraBackup 2.3,安装指导请参见官方文档Percona XtraBackup 2.3
  • MySQL 5.7版本需要安装 Percona XtraBackup 2.4,安装指导请参见官方文档Percona XtraBackup 2.4
  • MySQL 8.0版本需要安装 Percona XtraBackup 8.0,安装指导请参见官方文档Percona XtraBackup 8.0

三、脚本编写和测试

1. 编写SHELL脚本

#!/usr/bin/env bash
#########数据库基础信息#############
#输入参数
URL_PATH=$
#定义时间格式
DATE=`date +%Y%m%d%H%M%S`
#日志记录文件地址
LOG_PATH=/data/db_bakup/bakup.log
#保存备份个数
BACK_NUM=
#备份文件存放路径
BAKUP_PATH=/data/db_bakup/ ##########################
back_up(){
cd ${BAKUP_PATH}
echo "===${DATE}-下载备份,URL_PATH=${URL_PATH}===" >> ${LOG_PATH}
wget -c "${URL_PATH}" -O database.${DATE}.tar.gz
echo "===创建文件夹用于存放解压文件===" >> ${LOG_PATH}
mkdir database.${DATE}
echo "===解压database.${DATE}===" >> ${LOG_PATH}
tar -izxvf database.${DATE}.tar.gz -C database.${DATE}
echo "===恢复解压好的备份文件===" >> ${LOG_PATH}
innobackupex --defaults-file=/data/db_bakup/database.${DATE}/backup-my.cnf --apply-log /data/db_bakup/database.${DATE}
echo "===停止数据库===" >> ${LOG_PATH}
service mysql stop
#删除数据库data软链接(我的数据库安装在/data/mysql/)
rm -rf /data/mysql/data
echo "===删除原数据库文件夹===" >> ${LOG_PATH}
#删除原数据库文件夹
rm -rf database/
#更名
mv database.${DATE} database
#新建数据库软链接
ln -s /data/db_bakup/database /data/mysql/data
#创建版本号文件(方便辨认当前数据库备份是属于哪个版本的)
touch database/rev.database
cat "${DATE}" >> database/rev.database
echo "===修改文件属主===" >> ${LOG_PATH}
chown -R mysql:mysql /data/db_bakup/database
chown -R mysql:mysql /data/mysql
echo "===重启数据库===" >> ${LOG_PATH}
service mysql start
#找出需要删除的备份
delfile=`ls -l -crt ${BAKUP_PATH}/*.tar.gz | awk '{print $9 }' | head -1` #判断现在的备份数量是否大于$number
count=`ls -l -crt ${BAKUP_PATH}/*.tar.gz | awk '{print $9 }' | wc -l`
if [[ $count -gt $BACK_NUM ]];then
#删除最早生成的备份,只保留number数量的备份
rm $delfile
#写删除文件日志
echo "delete $delfile" >> ${LOG_PATH}
fi
echo "===结束===" >> ${LOG_PATH}
}
back_up;

脚本保存文件为: /data/db_bakup/back_up.sh

2. 给文件增加运行权限

chmod u+x /data/db_bakup/back_up.sh

3. 启动备份命令:

sh /data/db_bakup/back_up.sh "备份文件下载链接"

注意:"备份文件下载链接" 从阿里云RDS管理控制台复制获取

4. 查看备份日志查看进程

tail -f  /data/db_bakup/bakup.log -n 

5. 登录数据库查看是否已经切换到新的备份

mysql -uroot -p

6. 完毕~~~

参考文献:

RDS for MySQL 物理备份文件恢复到自建数据库

阿里云RDS数据库备份同步到自建库方法(SHELL脚本)的更多相关文章

  1. 【故障公告】阿里云 RDS 数据库服务器 CPU 100% 造成全站故障

    非常非常抱歉,今晚 19:34 ~ 21:16 园子所使用的阿里云 RDS 数据库服务器突然出现 CPU 100% 问题,造成全站无法正常访问,由此您带来了很大的麻烦,请您谅解. 故障经过是这样的.1 ...

  2. 云上的芯脏病:奇怪的阿里云 RDS 数据库突发 CPU 近 100% 问题

    最近遇到了奇怪的阿里云 RDS 数据库突发 CPU 近 100% 问题,遇到了3次. 第一次是10月12日(周六)凌晨 3:24 负载极低的时候开始出现,早上发现后进行了主备切换,恢复了正常. 第二次 ...

  3. 阿里云 RDS 数据库又发 CPU 近 100% 的“芯脏病”

    最近云界发生了2件事,一件是大事,一件是小事,大事是阿里云与微软合作推出了开放应用模型 Open Application Model(OAM),小事是由于微软 SQL Server 在阿里云上水土不服 ...

  4. 阿里云RDS数据库改造迁移方案

    1. 改造原因 (1) 由于历史原因, 本应该是同一个库的表分布在两个数据库中,需要对这两个库进行合并. (2) 已有的数据库性能无法满足业务的增长需要, 查询卡,慢问题突出. (3) 当前自建Mys ...

  5. 阿里云rds数据库迁移实战(多数据源)

    由于某几个业务表数据量太大,数据由业务写,数据部门读. 写压力不大,读却很容易导致长时间等待问题(读由单独系统进行读),导致连接被占用,从而容易并发稍稍增长导致全库卡死! 于是,就拆库呗. 业务系统拆 ...

  6. 【故障公告】阿里云 RDS 数据库突发 CPU 近 100% 引发全站故障

    今天晚上9点我们收到阿里云的告警通知: [阿里云监控]华东1(杭州)-云数据库RDS版<cnblogsdb> [instanceId=xxx] 于21:00 发生告警, 前往诊断 CPU使 ...

  7. 阿里云RDS数据库备份文件恢复到本地mysql数据库

    一.安装mysql和xtrabackup  (1)安装mysql 因为RDS是5.6版本,所以我们本地的mysql数据库要与RDS版本对应. rpm -ivh http://repo.mysql.co ...

  8. 阿里云RDS数据库sql server 导入数据并添加作业小结

    在阿里云购买ECS服务器和RDS数据库时,要注意网络类型要一致,最好都是VPC,否则ECS不能在内网访问RDS,只能从外网访问:在RDS控制台左侧,数据库安全性的IP白名单中添加ECS外网IP:在数据 ...

  9. 阿里云mysql数据库备份还原

    1.下载备份包 在rds的备份恢复中点击下载,在弹出的窗口中复制内网下载地址(前提是目标服务器与rds内网互通,否则请复制外网地址) 在目标服务器中执行如下命令进行下载: wget -c '复制的地址 ...

随机推荐

  1. C#动态创建单例类的对象

    单例类 public class SnappingClass : ISnappingEnvironment, IExtension { // private static readonly Snapp ...

  2. c# 移除类中所有事件的绑定

    单例中为防止多处注册事件引起异步触发时发生报错,网上找了一圈没找到想要的方法. [异常类型]:ArgumentException[异常信息]:该委托必须有一个目标(且仅有一个目标). 结合网上资料整合 ...

  3. sqlserver the name is not a valid identifier error in function

    参考资料:https://stackoverflow.com/questions/22008859/the-name-is-not-a-valid-identifier-error-in-functi ...

  4. Map-HashMap-遍历

    第一种遍历方法 : 先获取Map中的所有key值,然后根据key,依次从Map中去数据 (针对只取 Key 或者 Value 的情况) Map<String, String> hashMa ...

  5. C#解析JSON数组

    方式一 第一步:使用前,需下载:Newtonsoft.Json.dll 没有的,请到我百度云盘下载 链接:https://pan.baidu.com/s/1JBkee4qhtW7XOyYFiGOL2Q ...

  6. 十一:外观模式详解(Service,action与dao)

    定义:外观模式是软件工程中常用的一种软件设计模式.它为子系统中的一组接口提供一个统一的高层接口.这一接口使得子系统更加容易使用. 该定义引自百度百科,它的表现很简单,将一系列子接口的功能进行整理,从而 ...

  7. JS初始

      简单只和复杂值的区别 1.简单值 简单值表示JS中可用的数据或信息的最底层简单形式. 注:简单之不可被细化. 也就是说,数字是数字,字符是字符,布尔值是true或false,null和undefi ...

  8. 如何使用Postman发送get请求?

    一.接口测试介绍 接口测试:就是针对软件对外提供服务的接口输入输出进行测试,以及接口间相互逻辑的测试,验证接口功能和接口描述文档的一致性. 接口测试好处:接口测试通常能对系统测试的更为彻底,更高的保障 ...

  9. 终端的乐趣--Linux下有趣的终端命令或者工具【转】

    转自:https://blog.csdn.net/gatieme/article/details/52144603 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原 ...

  10. Gitlab批量迁移项目

    最近接到一个需求,要把一个Gitlab上边的项目全部导入到另外一个Gitlab,借鉴了网上的一个方法,成功实现. 参考链接:https://segmentfault.com/a/11900000159 ...