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异地备份方案经验总结的更多相关文章

  1. MySQL常见备份方案

    MySQL常见备份方案有以下三种: mysqldump + binlog lvm + binlog xtrabackup 本例为方便演示,数据库里面数据为空.下面开始动手 mkdir /opt/bac ...

  2. 原创|高逼格企业级MySQL数据库备份方案,原来是这样....

    很多人,这里说的是运维工程师们,一提到写某某方案,很是头疼.不是上某度一统搜索,就是同样一句话在N个群全部群发一遍:“有没有某某方案,可以共享一下的吗??求助,各位大佬们”,估计十有八九,全部石沉大海 ...

  3. 高逼格企业级MySQL数据库备份方案,原来是这样....

    很多人,这里说的是运维工程师们,一提到写某某方案,很是头疼.不是上某度一统搜索,就是同样一句话在N个群全部群发一遍:“有没有某某方案,可以共享一下的吗??求助,各位大佬们”,估计十有八九,全部石沉大海 ...

  4. Linux shell实现Mysql异地备份数据库

    #--------------------------Mysqldump异地备份-----------------# #!/bin/bash #start mysqldump back /usr/bi ...

  5. mysql 数据库备份方案及策略

    由于mysql存在多种数据库备份方式,而且各有利弊,对于我们初学者来说,选择合适的备份方式确实有些困难.个人觉得,首先要基于公司的需求,考虑能够容忍丢失多少数据.花多少人力时间成本等,这是我们制定备份 ...

  6. mySQL 增量备份方案(转)

    1.在 /etc/my.cnf 下面设置开启bin-log 编辑 vim /etc/my.cnf [mysqld] binlog_format       = MIXED                ...

  7. mySQL 增量备份方案

    1.在 /etc/my.cnf 下面设置开启bin-log 编辑 vim /etc/my.cnf [mysqld] binlog_format       = MIXED                ...

  8. MYSQL数据库自动本地/异地双备份/MYSQL增量备份

    构建高安全电子商务网站之(网站文件及数据库自动本地/异地双备份)架构图 继续介绍Linux服务器文件备份,数据库备份,数据安全存储相关的电子商务系统架构.针对安全性有多种多样的解决方案,其中数据备份是 ...

  9. Mysql备份系列(1)--备份方案总结性梳理

    mysql数据库备份有多么重要已不需过多赘述了,废话不多说!以下总结了mysql数据库的几种备份方案: 一.binlog二进制日志通常作为备份的重要资源,所以再说备份方案之前先总结一下binlog日志 ...

随机推荐

  1. 操作系统开发之——打开A20

    我们在上一篇文章提到.怎样制作Bootsect.当然,人总是贪婪的,制作完Bootsect又想着做Setup了,Setup主要工作是打开A20,进入保护模式,等等. 一.介绍A20 这是一个历史性问题 ...

  2. 一个MySQL-JDBC驱动bug引起的血案……

    问题背景 公司是做电商系统的,整个系统搭建在华为云上.系统设计的时候,考虑到后续的用户和订单数量比较大,需要使用一些大数据库的组件.关系型数据库这块,考虑到后续数据量的快速增长,不是直接写入MySQL ...

  3. hdu5371 最长回文子串变形(Manacher算法)

    pid=5371">http://acm.hdu.edu.cn/showproblem.php? pid=5371 Problem Description Hotaru Ichijou ...

  4. network adapter

    1 network adapter 网络适配器,也叫网卡,是一个硬件. 2 关于以太网卡 以太网卡分为光纤以太网卡和电口以太网卡. 3 常用的以太网卡 3.1 AMD PCNet PCI II (Am ...

  5. jenkins安装和使用

    1 jenkins安装 直接下载deb包,离线安装. 2 plugin的安装 直接下载hpi包,离线安装. 我在一次安装的时候,在配置gitlab时,在test connection的时候,出现了nu ...

  6. algorithm库———count&&countif

    algorithm头文件定义了一个count的函数,其功能类似于find.这个函数使用一对迭代器和一个值做参数,返回这个值出现次数的统计结果. 编写程序读取一系列int型数据,并将它们存储到vecto ...

  7. [Apple开发者帐户帮助]七、注册设备(3)禁用或启用设备

    您可以禁用和启用设备,但不能从开发者帐户中删除它.您可以禁用不再用于开发或测试的设备.但是,这样做会使包含设备的配置文件无效,并且不会增加当年设备的总数. 所需角色:帐户持有人或管理员. 在“ 证书” ...

  8. Akka源码分析-Remote-位置透明

    上一篇博客中,我们研究了remote模式下如何发消息给远程actor,其实无论如何,最终都是通过RemoteActorRef来发送消息的.另外官网也明确说明了,ActorRef是可以忽略网络位置的,这 ...

  9. JVM-垃圾回收器

    目录 垃圾收集器 Serial收集器 Serial Old 收集器 ParNew 收集器 Parallel Scavenge 收集器 (并行清除) /'pærəlɛl/ /'skævɪndʒ/ Par ...

  10. C#学习-程序集和反射

    准备项目 1.新建一个空的解决方案MyProj.sln 2.在该解决方案下,建一个控制台项目P01.csproj 3.在该项目下,自己新建一个类MyFirstClass.cs 查看解决方案MyProj ...