mysql异地备份方案经验总结
Mysql 数据库异地备份脚本
实验环境:关闭防火墙不然不能授权登录
Mysql-server:192.168.30.25
Mysql-client: 192.168.30.24
实验要求:对mysql-server 的auth和client库实现异地备份,每天凌晨2:00进行备份
并写一个数据恢复脚本(库里有数据)
mysql服务端授权,给予select和lock tables 权限,已备份
[root@localhost ~]# mysql -uroot -p123456
mysql> grant select,lock tables on auth.* to 'admin'@'192.168.30.24'identified by '123456';
mysql> grant select,lock tables on client.* to 'admin'@'192.168.30.24' identified by '123456';
mysql> flush privileges;
连接测试
这个需要安装好后的mysql,连接测试
[root@client ~]# mysql -uadmin -p -h192.168.30.25
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| auth |
| client |
+--------------------+
3 rows in set (0.09 sec)
写客户端脚本
vim /opt/bakmysql.sh
#!/bin/bash
#mysql数据库备份脚本
#设置登录变量
MY_USER="admin"
MY_PASS="123456"
MY_HOST="192.168.30.25"
MY_CONN="-u$MY_USER -p$MY_PASS -h$MY_HOST"
#设置备份的数据库
MY_DB1="auth"
MY_DB2="client"
#定义备份路径,工具,时间,文件名
BF_DIR="backup"
BF_CMD="/usr/bin/mysqldump" 这里是mariadb的mysqldump路径
BF_TIME=$(date +%Y%m%d-%H%M)
NAME_1="$MY_DB1-$BF_TIME"
NAME_2="$MY_DB2-$BF_TIME"
#备份为.sql脚本,然后打包压缩(打包后删除原文件)
[ -d $BF_DIR ] || mkdir -p $BF_DIR
cd $BF_DIR
$BF_CMD $MY_CONN --databases $MY_DB1 > $NAME_1.sql
$BF_CMD $MY_CONN --databases $MY_DB2 > $NAME_2.sql
tar zcf $NAME_1.tar.gz $NAME_1.sql --remove &> /dev/null
tar zcf $NAME_2.tar.gz $NAME_2.sql --remove &> /dev/null
[root@client backup]#chmod +x /opt/bakmysql.sh
[root@client backup]#/opt/bakmsyql.sh
[root@client backup]#ls backup
[root@client backup]#crontab -e
0 2 * * * /opt/bakmsyql.sh
systemctl restart crond
[root@client backup]#date 040601592019.59 //MMDDhhmmYY.SS 月日小时分钟年.秒
可以用这个命令也可以主要修改系统时间,让备份多做几天的,然后我们让后面的脚本选择性恢复date -s “2019-05-26 01:59:55”
2019年 04月06日 星期日 01:59:59 CST
[root@client backup]# date 040701592019.59
2019年 04月 07日 星期日 01:59:59 CST
[root@client backup]# date 040801592019.59
2019年 04月 08日 星期一 01:59:59 CST
撰写数据恢复脚本
vim /opt/restore_mysql.sh
#!/bin/bash
#恢复mysql数据库数据脚本
#设置变量
MY_USER="admin"
MY_PASS="123456"
MY_HOST="192.168.30.23"
BF_DIR="backup"
mkdir .aaa &> /dev/null
ls $BF_DIR |column -t > .aaa/db_list
awk -F'-' '{print $2}' .aaa/db_list > .aaa/dt.txt
read -p "请指定要恢复数据库的日期(YYYYMMDD):" dt
if [ $dt -ge 20190501 ] && [ $dt -le 20190601 ]
then
grep "$dt" .aaa/dt.txt &> /dev/null
if [ $? -ne 0 ]
then
echo "很抱歉,您恢复的数据库备份日期不在备份日期范围内"
else
echo "搜索到的可恢复数据库如下:"
awk -F'-' /$dt/'{print NR,$1}' .aaa/db_list
read -p "请选择您要恢复数据库的编号:" nb
nm=$(awk -F'-' /$dt/'{print NR,$1}' .aaa/db_list |awk /$nb/'{print $2}')
echo "现在开始恢复数据库:$nm 到$dt"
cd $BF_DIR
onm=$(ls |grep "$nm-$dt")
mkdir .bbb
tar xf $onm -C .bbb
mysql -u$MY_USER -p$MY_PASS -h$MY_host $nm < .bbb/*
echo "$nm 已经恢复到$dt"
rm -rf .bbb
cd - &> /dev/null
rm -rf .aaa
fi
else
echo "很抱歉,您恢复数据库的备份日期不在备份日期范围内"
fi
server端授权
chmod +x /opt/restore_mysql.sh
Mysql >grant all on auth.* to ‘admin’@’192.168.30.24’;
Mysql >grant all on client.* to ‘admin’@’192.168.30.24’;
Mysql > flush privileges;
恢复测试
执行脚本
/opt/restore_mysql.sh
mysql异地备份方案经验总结的更多相关文章
- MySQL常见备份方案
MySQL常见备份方案有以下三种: mysqldump + binlog lvm + binlog xtrabackup 本例为方便演示,数据库里面数据为空.下面开始动手 mkdir /opt/bac ...
- 原创|高逼格企业级MySQL数据库备份方案,原来是这样....
很多人,这里说的是运维工程师们,一提到写某某方案,很是头疼.不是上某度一统搜索,就是同样一句话在N个群全部群发一遍:“有没有某某方案,可以共享一下的吗??求助,各位大佬们”,估计十有八九,全部石沉大海 ...
- 高逼格企业级MySQL数据库备份方案,原来是这样....
很多人,这里说的是运维工程师们,一提到写某某方案,很是头疼.不是上某度一统搜索,就是同样一句话在N个群全部群发一遍:“有没有某某方案,可以共享一下的吗??求助,各位大佬们”,估计十有八九,全部石沉大海 ...
- Linux shell实现Mysql异地备份数据库
#--------------------------Mysqldump异地备份-----------------# #!/bin/bash #start mysqldump back /usr/bi ...
- mysql 数据库备份方案及策略
由于mysql存在多种数据库备份方式,而且各有利弊,对于我们初学者来说,选择合适的备份方式确实有些困难.个人觉得,首先要基于公司的需求,考虑能够容忍丢失多少数据.花多少人力时间成本等,这是我们制定备份 ...
- mySQL 增量备份方案(转)
1.在 /etc/my.cnf 下面设置开启bin-log 编辑 vim /etc/my.cnf [mysqld] binlog_format = MIXED ...
- mySQL 增量备份方案
1.在 /etc/my.cnf 下面设置开启bin-log 编辑 vim /etc/my.cnf [mysqld] binlog_format = MIXED ...
- MYSQL数据库自动本地/异地双备份/MYSQL增量备份
构建高安全电子商务网站之(网站文件及数据库自动本地/异地双备份)架构图 继续介绍Linux服务器文件备份,数据库备份,数据安全存储相关的电子商务系统架构.针对安全性有多种多样的解决方案,其中数据备份是 ...
- Mysql备份系列(1)--备份方案总结性梳理
mysql数据库备份有多么重要已不需过多赘述了,废话不多说!以下总结了mysql数据库的几种备份方案: 一.binlog二进制日志通常作为备份的重要资源,所以再说备份方案之前先总结一下binlog日志 ...
随机推荐
- Wincc操作数据库SQLSERVER
WINCC写数据库 在WINCC的图形编辑器中,在输入域的属性中.选择事件.再选择键盘的释放动作,在动作代码框中写下例如以下代码: Dim conn,rs Dim strsql Dim a a=HM ...
- Java Web开发基础(1)-Servlet
概述 Servlet技术是对webserver的扩展,要理解这个,可能先了解一下什么是Webserver以及它的功能,特别是它的不足是非常有帮助的,可參考:点击打开链接.另外.Servlet也是一个用 ...
- CSDN学院 免费技术答疑公开课,本周六场即将开播~~~
为了酬谢广大学员.CSDN学院特推出免费技术答疑公开课.让您开启一段充实的学习之旅~ 本周六场即将开播. ----------------------------------------------- ...
- vim随想笔记(1)
本人是一个vim的狂热粉丝,越是使用vim,越是认为琐碎内容太多,时不时地出现一些自己没有见过的使用方法.命令. 因此准备在博客上用空余时间在阅读<学习vi和vim编辑器>的基础上总结一下 ...
- LeetCode 884. Uncommon Words from Two Sentences (两句话中的不常见单词)
题目标签:HashMap 题目给了我们两个句子,让我们找出不常见单词,只出现过一次的单词就是不常见单词. 把A 和 B 里的word 都存入 map,记录它们出现的次数.之后遍历map,把只出现过一次 ...
- [Unity UGUI]ScrollRect效果大全
UGUI各种优化效果 本文所实现的UGUI效果需求如下: - 支持缩放滑动效果 - 支持动态缩放循环加载 - 支持大数据固定Item复用加载 - 支持不用Mask遮罩无限循环加载 - 支持Object ...
- P4700 算
P4700 算 时间: 1000ms / 空间: 125829120KiB / Java类名: Main 背景 zhx和他的妹子出去玩. 描述
- js将图片转为base64编码,以字符串传到后台存入数据库
(前台在中approve_edit.html中,后台不变) 链接参考:http://www.cnblogs.com/Strom-HYL/p/6782176.html 该链接文中并没有用到easyUI的 ...
- android binder 基础实例及解析(一)【转】
本文转载自:http://blog.csdn.net/newchenxf/article/details/49359283#insertcode 原文网址(转载请注明出处): http://blog. ...
- JZOJ 1003 [ 东莞市选 2007 ] 拦截导弹 —— 递推
题目:https://jzoj.net/senior/#main/show/1003 n^2 的话递推就可以啦. 代码如下: #include<iostream> #include< ...