mysql备份恢复

mysql备份主要方式有完全备份与增量备份。完全备份是对整个数据库的备份、数据库结构和文件结构的备份,保存的是备份完成时刻的数据库,是增量备份的基础。

备份方式分为物理与逻辑角度分为:
物理备份
冷备份:在数据关闭的状态下运行
热备份:在数据库运行的状态时进行备份操作,该备份方法依赖数据库日志文件。
温备份:数据局锁定表格(可以读不可以写)的状态年备份数据库
逻辑备份:对数据库逻辑组件(如表等数据库对象)的备份,表示为逻辑数据结构(create database、create tabale)和内容(insert语句或分割文本文件)的信息
数据库备份策略角度,备份分为:完全备份、差异备份和增量备份
完全备份:每次对数据进行完整备份。但它需要更多的时间和空间,做一次完全备份相对周期长。
差异备份:备份哪些自从上次完全备份的所有文件,备份的时间节点是从上次完整备份起,备份的数据量会越来越大,恢复数据只是恢复上次的完整备份和最近一次的差异备份。
增量备份:只有那些在上次完全备份或者增量备份后被修改的文件才会备份,以上次完成整备份,或者上次的增量备份的时间点,
仅备份这之间的数据变化,因而备份的数据量小,占用空间小,备份数据速度快,但恢复时候,需要从上次的完整备份
开始到最后一次的增量备份之间所有的增量依次恢复,如中间某次的恢复数据备份损坏,将导致数据的丢失。

——————————————————————————
实际演练
1物理冷备份与恢复(tar命令直接打包数据库文件夹)
备份数据库:
[root@localhost ~]# systemctl stop mysqld ###关闭数据库####
[root@localhost ~]# mkdir /backup ###在根下新建个backup目录
[root@localhost ~]# tar zcf /backup/mysql_all-$(date +%F).tar.gz /usr/local/mysql/data/ #####/usr/local/mysql/data备份压缩
[root@localhost ~]# cd /backup/ ###进入/backup/
[root@localhost backup]# ll ##查看备份
◆数据库恢复
[root@localhost mysql]# mkdir /restore ####根目录新建restore 目录
[root@localhost mysql]# tar xzvf /backup/mysql_all-2018-08-12.tar.gz -C /restore/ ####将备份数据库解压到 /restore目录下 不要无脑刷,时间节点不一样
usr/local/mysql/data/
usr/local/mysql/data/ibdata1
usr/local/mysql/data/ib_logfile1
MySQL数据库增量备份恢复
1、增量备份的特点
与完全备份完全不同,增量备份没有重复数据,备份量不大,时间短;但其恢复麻烦,需要上次完成完全备份及备份之后的所有增量备份才能恢复。
2、MySQL数据库二进制日志对备份的意义
二进制日志保存了所有更新或者可能更新数据的操作。二进制日志在启动mysql服务器后开始记录,并在文件达到二进制日志所设置的最大值
或者接受到flush logs命令后重新创建新的日志文件,生成二进制的文件序列,并及时把这些日志文件保存到安全的存储位置,即可完成一个时间段的增量备份。
[root@localhost mysql]# vim /etc/my.cnf #####编辑my.cnf配置文件
[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld] #####找到这个模块
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1
log-bin=/usr/local/mysql/data/mysql-bin ####这个地方开启二进制日志功能

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
[root@localhost mysql]# systemctl restart mysqld ####重启数据库
[root@localhost ~]# ll /usr/local/mysql/data/
增量恢复的方法
一般恢复:
mysqlbinlog [–no-defaults] 增量备份文件 | mysql -u 用户名 -p
基于位置的恢复
mysqlbinlog --stop-position=’操作 id’ 二进制日志 |mysql -u 用户名 -p 密码
从指定的位置开始恢复数据
mysqlbinlog --start-position=’操作 id’ 二进制日志 |mysql -u 用户名 -p 密码
基于时间点的恢复:
从日志开头截止到某个时间点的恢复
mysqlbinlog [–no-defaults] --stop-datetime=’年-月-日 小时:分钟:秒’ 二进制日志 | mysql -u 用户名 -p 密码
从某个时间点到日志结尾的恢复
mysqlbinlog [–no-defaults] --start-datetime=’年-月-日 小时:分钟:秒’ 二进制日志 | mysql -u 用户名 -p 密码
从某个时间点到某个时间点的恢复
mysqlbinlog [–no-defaults] --start-datetime=’年-月-日 小时:分钟:秒’ --stop-datetime=’年-月-日小时:分钟:秒’ 二进制日志 | mysql -u 用户名 -p 密码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值