mysql多种备份与恢复方式一
基于mysql社区版5.7,严重声明:本文中图方便直接写入了-p数据库密码,在生产环境中如果指定了一定要使用history -C清空历史命令记录哦,所有博客作者原创纯手打,转载一定要注明本博客链接,感谢!
通过mysqldump方式进行备份和恢复
物理备份:拷贝mysql下的数据目录将其备份即为物理备份。
逻辑备份:使用mysqldump进行备份可以进行逻辑备份。
完全备份:备份所有数据。
增量备份:备份上次备份后,所有新产生的数据。
差异备份:备份完全备份后,所有产生的数据。
mysqldump -uroot -ppassword 库名 > /目录/备份文件名.sql
#使用mysqldump逻辑备份时会自动锁表,导致数据无法写入。正好可以使用这一特性,组合--flush-logs刷新binlog日志,这样
#可以使得备份完成后刷新日志,对日志进行断点。可以在出现故障的第一时间使用备份后开始的binlog进行恢复,可以提升一部分效率。
备份时库名表示方式:
* --all-databases 或 -A //备份所有库
* 数据库名 //备份单个库
* 数据库名 表名 //单张表
* -B 数据库1 数据库2 //多个库
mysql -uroot -ppassword [库名] < 目录/xxx.sql
通过binlog日志进行恢复
binlog日志也称作二进制日志,记录除查询外的所有的SQL命令,可以用于数据备份和恢复,配置mysql主从同步的必要条件。
要使用binlog日志必须要要先打开binlog日志记录功能,在/etc/my.cnf下打开#log_bin注释
log_bin=/binlog存放目录/命名前缀
# 可以单独只打开log_bin,而不指定路径和名字,将默认存放到mysql主文件夹中,在rpm包安装中默认路径是/var/lib/mysql目录,名称
#前缀也可以不指定默认使用主机名作为前缀,设定了存放目录后要给mysql写入权限才能使用,如果不给写入权限会导致服务无法启动。
server_id=1
# 指定服务器ID值范围1-255,开启binlog一定要设置服务器ID不设定也会无法启动服务。
max_binlog_size=数值m
# 指定日志文件容量,默认1G
binlog_format="Mixed"
# 指定binlog日志记录模式,修改为mixed模式。三种日志记录模式分别是:row(行模式)、statement(报表模式)、mixed(混合模式)
在修改配置文件后需要将mysql重启服务才能生效。
show master status ;
File Position Binlog_Do_DB Binlog_Ignore_DB Executed_Gtid_Set 当前日志文件 偏移量 只记录指定数据库的二进制日志 不记录指定数据库的二进制日志 已执行的事务编号 看到File和Positiion有值后即为打开成功。
在数据库主从同步的时候也是必须要打开binlog日志的。
删除指定编号之前的binlog日志文件:purge master logs to "binlog文件名"。
删除所有的binlog日志,重建日志:reset master。
通过在数据库命令行中查询binlog日志查看日志记录模式是否改成混合模式。
show variables like "%binlog_format%";
#如果values是MIXED则说明开启了混合模式。
说到这里又要扯到mysql binlog三种模式。
模式 优点 缺点 row(行模式) 非常清楚记录下每一行数据被修改的细节,可以很好支持存储过程和function以及trigger调用和触发器。 主从同步占用大量磁盘IO,日志量巨大。 statement(报表模式) 记录每一条修改数据的SQL语句事件,并非每条更改记录。减少了binlog日志量,节约磁盘IO,提升性能。 函数、存储过程的复制不能很好的支持,导致有时主从同步出现问题。 Mixed(混合模式) MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志格式,也就是在Statement和Row之间选择一种,缓和了磁盘IO,和日志文件大小。 兼顾解决磁盘IO问题,但未测试函数、存储过程等。(看下方) # at 285168
#191014 23:35:10 server id 1 end_log_pos 285199 CRC32 0x0cb3a5df Xid = 3048
COMMIT/*!*/;
# at 285199
#191014 23:36:23 server id 1 end_log_pos 285264 CRC32 0x9d6c36f7 Anonymous_GTID last_committed=1012 sequence_number=1013
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
# at 285264
#191014 23:36:23 server id 1 end_log_pos 285342 CRC32 0xa7d96de8 Query thread_id=1016 exec_time=0 error_code=0
SET TIMESTAMP=1571067383/*!*/;
BEGIN
/*!*/;
# at 285342
#191014 23:36:23 server id 1 end_log_pos 285439 CRC32 0x379d2612 Query thread_id=1016 exec_time=0 error_code=0
SET TIMESTAMP=1571067383/*!*/;
delete from userdb2.tb1
/*!*/;
通过binlog时间区间/偏移量进行恢复
mysqlbinlog [选项] binlog日志文件名 | mysql -uroot -p
选项 --start-datetime="yyyy-mm-dd hh:mm:ss" --stop-datetime="yyyy-mm-dd hh:mm:ss" --strat-position=偏移量 --stop-position=偏移量 恢复思路:
- 第一步首先通过上次的完整备份恢复到完整备份之前的状态。
- 第二步通过binlog定位到完整备份之后到当前删库之前的偏移量得到起始偏移量和结束偏移量(或者时间)。
- 第三步准确恢复校对数据。
- 思路校验:
- 先创建测试库测试表然后通过循环进行插入数据。
mysql -uroot -p12345 -e "create database testdb charset=utf8;"
mysql -uroot -p12345 -e "create table testdb.testtb1(id int);"
for i in {1..1000};do mysql -uroot -p12345 -e "insert into testdb.testtb1(id) values($i);" ;done
- 然后通过mysqldump对数据库testdb进行完整备份。
mysqldump -uroot -p12345 --flush-logs -B testdb > /tmp/testdb.sql
#参数-B和不加有何区别?
#1.区别就在于加参数B后可以指定备份数据库列表。
#2.生成的数据库备份文件中含有创建数据库和选择数据库的指令。
#CREATE DATABASE /*!32312 IF NOT EXISTS*/ `testdb` /*!40100 DEFAULT CHARACTER SET utf8 */;
#USE `testdb`;
- 模拟用户写入数据1001条。
for i in {3000..4000};do mysql -uroot -p12345 -e "insert into testdb.testtb1(id) values($i);" ;done && mysql -uroot -p12345 -e "insert into testdb.testtb1(id) values(666);" ;
- 然后测试删库
mysql -uroot -p12345 -e "drop database testdb;"
- 然后使用完整备份记录进行恢复。
mysql -uroot -p12345 < testdb.sql
- 使用上次完整备份的记录恢复后,中间还有用户写入的1000条数据,可以通过binlog偏移量(时间差)进行恢复,先定位上次备份结束的位置
[root@db-master tmp]# mysql -uroot -p12345 -e "select count(*) from testdb.testtb1"
mysql: [Warning] Using a password on the command line interface can be insecure.
+----------+
| count(*) |
+----------+
| 1000 |
+----------+ # at 869709
#191015 0:19:55 server id 1 end_log_pos 875708 CRC32 0x9b4fd429 Query thread_id=3032 exec_time=0 error_code=0
SET TIMESTAMP=1571069995/*!*/;
******************************************************************************************
内容过多省略
******************************************************************************************
# at 875708
#191015 0:19:56 server id 1 end_log_pos 296078 CRC32 0x84203c10 Query thread_id=4040 exec_time=0 error_code=0
SET TIMESTAMP=1571071195/*!*/;
insert into testdb.testtb1(id) values(666)
/*!*/;- 通过偏移量进行恢复(也可以指定binlog文件和结束偏移量恢复到删库前一条,不带开始偏移量。)
mysqlbinlog --strat-position=869709 --stop-position=875708 /logfile/lqh.000001 | mysql -uroot -p12345
mysql多种备份与恢复方式一的更多相关文章
- mysql多种备份方式比较及实现
Mysql备份 MySQL的备份和还原: 备份:存放为副本-->数据备份 RAID1,RAID10:保证硬件损坏而不会业务中止,不能保证逻辑上的损害 例如:DROP TABLE mydb.tb1 ...
- MySQL多种安装方式选择
1.rpm包安装方式 rpm包的安装方式非常简单,这里以el6平台下的mysql-5.6.34版本为例,首先,要通过上述搜狐镜像地址下载到如下四个MySQL相关软件安装包. a.下载安装包 MySQL ...
- 2020重新出发,MySql基础,MySql数据库备份与恢复
@ 目录 MySQL数据库备份与恢复 数据库为什么需要备份 MySQL备份类型 MySQL热备份及恢复 逻辑备份 mysqldump SELECT INTO-OUTFILE mydumper 裸文件备 ...
- Linux 平台MySQL启动关闭方式总结
MySQL的启动方法有很多种,下面对比.总结这几种方法的一些差异和特性,下面实验的版本为MySQL 5.6.如有疏漏或不足,敬请指点一二. 1:使用mysqld启动.关闭MySQL服务 mysql ...
- mysql查询优化之一:mysql查询优化常用方式
一.为什么查询速度会慢? 一个查询的生命周期大致可以按照顺序来看:从客户端,到服务器,然后在服务器上进行解析,生成执行计划,执行,并返回结果给客户端.其中在“执行”阶段包含了大量为了检索数据到存储引擎 ...
- MYSQL的备份与恢复--逻辑备份mysqldump
目录 0.备份与恢复概述 1.逻辑备份-完整备份与恢复 2.逻辑备份-增量备份与恢复 (1)环境准备 (2)恢复全量数据 (3)恢复增量备份 3.新来的开发妹子删了库! (1)模拟环境准备 (2)全备 ...
- MYSQL的备份与恢复--物理备份xrabackup
目录 1.数据库完整备份与恢复 (1)环境准备 (2)完全备份恢复流程 2.数据库增量备份与恢复 (1)增量和差异概述 (2)增量备份和恢复 3.数据库差异备份与恢复 4.简单命令进行物理备份 5.实 ...
- C#高性能TCP服务的多种实现方式
哎~~ 想想大部分园友应该对 "高性能" 字样更感兴趣,为了吸引眼球所以标题中一定要突出,其实我更喜欢的标题是<猴赛雷,C#编写TCP服务的花样姿势!>. 本篇文章的主 ...
- C#开发微信门户及应用(11)--微信菜单的多种表现方式介绍
在前面一系列文章中,我们可以看到微信自定义菜单的重要性,可以说微信公众号账号中,菜单是用户的第一印象,我们要规划好这些菜单的内容,布局等信息.根据微信菜单的定义,我们可以看到,一般菜单主要分为两种,一 ...
随机推荐
- ELK日志分析系统(3)-logstash数据处理
1. 概述 logspout收集数据以后,就会把数据发送给logstash进行处理,本文主要讲解logstash的input, filter, output处理 2. input 数据的输入处理 支持 ...
- Android Studio 优秀插件: Parcelable Code Generator
这里假设我们已经会使用 Parcelable 序列化一个对象了~~ 那么大家会发现 Parcelable 使用起来有些复杂,因为我们要自己复写 几个方法,而且当类的属性比较多的时候,我们就会难受了,又 ...
- 开发一个带UI的库(asp.net core 3.0)
在GitHub上有个项目,本来是作为自己研究学习.net core的Demo,没想到很多同学在看,还给了很多星,所以觉得应该升成3.0,整理一下,写成博分享给学习.net core的同学们. 项目名称 ...
- docker镜像制作必备技能
正文 使用过docker的都知道dockerfile,其用于定义制作镜像的流程,由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像.可参考往期文章学习:docker基础知识整理 ...
- LeetCode初级算法--数组02:旋转数组
LeetCode初级算法--数组02:旋转数组 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/ ...
- SQL SERVER 日志如何进行收缩?
最近经历了一次服务器SQL SERVER 数据库服务器端事务日志爆满,导致服务器数据库写入不进数据的宕机事件,经过此次事件的发生,奉劝各位同仁一句,如果没有绝对的充足存储空间,数据库事务日志文 ...
- 配置VC++2010的glut库
VC++2010是一个成熟稳定的版本,微软的编译工具Visual Studio系列从VC6到如今的VC2019,功能非常强大,我们在开始学习C++和计算机图形学的时候,一般入手<<C++P ...
- [网络流 24 题] luoguP2756 飞行员配对方案问题
[返回网络流 24 题索引] 题目描述 英国皇家空军从沦陷国征募了大量外籍飞行员.由皇家空军派出的每一架飞机都需要配备在航行技能和语言上能互相配合的 222 名飞行员,其中 111 名是英国飞行员,另 ...
- NoticeBoard
本人蒟蒻,请轻点虐. 本人是一个即将退役的蒟蒻. 有些题目和模拟赛用密码保护起来了,请小伙伴们不要猜了,猜不出来的.想知道大佬们如果想查看可以直接找我问,您们高抬贵眼会让我受宠若惊. 哇终于有人找我要 ...
- [POJ2262] Goldbach’s Conjecture
Goldbach's Conjecture Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 48161 Accepted: ...