定义

  1. 数据备份:将源数据再次存储到新的位置
  2. 数据恢复:将备份好的数据重新应用到数据库系统

常见的备份类型:

  1. 按照是否备份整个数据集来分

    完全备份:备份从开始到执行备份这一时刻的所有数据集

    增量备份:备份从上次备份到这次备份时刻变化的数据集

    差异备份:备份从上一次完全备份到这一备份时刻变化的数据集
  2. 按照备份的数据库对象来分

    物理备份:通过复制数据集在文件系统中的文件来备份

    逻辑备份:在数据库的客户端工具上使用SQL语句,应用程序或其他脚本文件做备份的操作
  3. 按照备份时,还能提供的服务分类

    热备份:备份的过程中,可以对备份的数据集做读写操作

    温备份:备份的过程中,只能对备份的数据集只能做读操作,不可有写操作

    冷备份:备份的过程中,直接将服务下线,读写操作均无法执行

备份的数据内容:

  1. 数据;
  2. 二进制日志
  3. InnoDB存储以前的事务日志文件;
  4. 代码——存储过程,存储函数,触发器,事件调度器等;
  5. 当前服务器上用于启动数据服务是所使用的配置文件;
  6. 操作系统上与MySQL或MariaDB相关的配置——sudo任务、cron任务等;

备份方法

第一种方法:基于二进制文件的恢复

通过客户端命令工具:mysqlbinlog和二进制日志恢复数据库文件

  1. mysqlbinlog [options] log_file ...
  2. --start-datetime=
  3. --stop-datetime=
  4. --start-position=
  5. --stop-position=
  6. #例:通过position日志位置直接恢复
  7. mysqlbinlog /var/lib/mysql/mysqlbin.000001 --stop-position=1093 | mysql -uroot -proot

重定向输入到bin.sql文件中

第一步:算好要恢复数据的时间段,重定向输入到bin.sql文件中

  1. #通过时间轴
  2. mysqlbinlog --start-datetime="2019-06-08 22:55:13" --stop-datetime="2019-06-08 22:55:13" binlog.0000011 > bin.sql
  3. #通过position日志
  4. mysqlbinlog --start-position=1008 --stop-position=1093 binlog.0000011 > bin.sql
  5. #整个文件
  6. mysqlbinlog /var/lib/mysql/binlog.000006 > /root/bin.sql
  7. mysqlbinlog /var/lib/mysql/binlog.000007 >> /root/bin.sql

第二步:执行bin.sql文件还原

  1. source bin.sql
  2. # mysql -uroot -pxxx DATABASENAME < bin.sql

第二种方法:基于lvm2的备份

第一步:请求锁定所有表

  1. flush tables with read lock;

第二步:记录二进制日志文件及事件位置或时间点

  1. flush logs;
  2. mysql -uroot -proot -e 'show master status;' > /path/to/somefile

第三步:创建快照

  1. lvcreate -L # -s -p r -n NAME /DEV/VG_NAME/LV_NAME

第四步:释放锁

  1. unlock tables;

第五步:挂在快照卷,执行数据备份

第六步:备份完成后,删除快照卷

第七步:指定好策略,通过原卷备份二进制日志

第八步:还原的时候确保属组和属主是mysql:mysql

其中:如果是yum安装默认数据目录在/var/lib/mysql,如果需要更改

  1. ╭─root@localhost.localdomain /var/lib/mysql
  2. ╰─➤ vim /etc/my.cnf.d/server.cnf
  3. [mysqld]
  4. datadir=/mysql_data/
  5. pid_file=/mysql_data/localhost.pid
  6. socket=/mysql_data/mysql.sock
  7. wsrep_data_home_dir=/mysql_data/
  8. log-bin=mysql-bin
  9. [client]
  10. socket=/mysql_data/mysql.sock

第三种方法:备份工具mariabackup/Xtrabackup

注意:在MariaDB10.3.x及以上的版本用Percona XtraBackup工具会有问题;原因可能是MariaDB10.3以上版本的redo日志格式和之前不同了

官方文档

Percona的官方文档:https://www.percona.com/doc/percona-xtrabackup/2.4/index.html

Mariabackup的官方文档:https://mariadb.com/kb/en/library/mariabackup-overview/

安装方法

  1. yum install MariaDB-backup

备份与恢复

全备+恢复

  1. #全量备份
  2. mariabackup --backup --target-dir=/root/fullbackup --user=root --password=root
  3. #准备全备数据
  4. mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root
  5. #还原数据(请确保数据目录下是空的)
  6. mariabackup --copy-back --target-dir=/root/fullbackup/ --user=root --password=root
  7. #修改属组和属主
  8. chown -R mysql.mysql /var/lib/mysql

全备+增量+恢复

  1. #1.全量备份
  2. mariabackup --backup --target-dir=/root/fullbackup --user=root --password=root
  3. #2.增量备份
  4. mariabackup --backup --target-dir=/root/inc1 --incremental-basedir=/root/fullbackup/ --user=root --password=root
  5. #3.准备全备数据
  6. mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root
  7. #4.增量和全备数据合并
  8. mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root --incremental-dir=/root/inc1/ --apply-log-only
  9. #5.恢复数据(请确保数据目录下是空的)
  10. mariabackup --copy-back --target-dir=/root/fullbackup/ --user=root --password=root
  11. #6.修改属组和属主
  12. chown -R mysql.mysql /var/lib/mysql

数据库备份和恢复---MariaDB的更多相关文章

  1. Sql Server数据库备份和恢复:原理篇

    本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...

  2. 使用exp&imp工具进行数据库备份及恢复

    使用exp&imp工具进行数据库备份及恢复1.exp/imp使用方法介绍exp/imp为一种数据库备份恢复工具,也可以作为不同数据库之间传递数据的工具,两个数据库所在的操作系统可以不同.exp ...

  3. MongoDB学习总结(六) —— 数据库备份和恢复

    我们都知道数据库数据经常备份是多么的重要,MongoDB作为一个数据库系统,自然提供了完善,丰富而且好用的备份与恢复机制. 以下介绍三种数据库备份和恢复的方式 > 数据目录直接拷贝 数据库目录直 ...

  4. asp.net针对SQLSERVER数据库备份和恢复的一揽子问题解决

    一.备份 先备份到服务端,用gridview显示出来,点击可以下载到本地 二.恢复 这是很麻烦的事情,本人查阅不少资料,耗费不少时间才搞定. 直接恢复数据库时不行的,会提示数据库正在使用,恢复失败等信 ...

  5. 小型网站MYSQL问题二:Percona Xtrabackup实现数据库备份和恢复

    1.安装软件仓库(不要问我为什么不用源码安装,好吧,其实我懒.) 1 2 3 4 5 6 7 8 wget https://www.percona.com/downloads/percona-rele ...

  6. C#可定制的数据库备份和恢复程序 (讲解流程)

    可定制的数据库备份和恢复程序 tashanzhishi [原作] 关键字 数据库 备份 恢复 出处 在我们做数据库系统的程序时,经常需要为客户做一个数据库的备份和恢复程序,特别是对于一些非专业的数据库 ...

  7. mysql基础之数据库备份和恢复实操

    一.基于二进制文件的恢复*** 1.算好要恢复数据的时间段,重定向输入到bin.sql文件中 [root@ren7 mysql]# mysqlbinlog --start-datetime=" ...

  8. postgresql数据库备份和恢复

    PostgreSQL自带一个客户端pgAdmin,里面有个备份,恢复选项,也能对数据库进行备份 恢复(还原),但最近发现数据库慢慢庞大的时候,经常出错,备份的文件过程中出错的几率那是相当大,手动调节灰 ...

  9. Oracle数据库备份、恢复及常见问题

    通常我们都是使用PL/SQL Developer来对Oracle中的数据对象和数据进行管理.如果我们想方便快速还原或者部署Oracle到新机器上,怎么进行数据库的备份.导入恢复呢? 这里我们必须要考虑 ...

随机推荐

  1. istio kiali 亲和性调度

    一.节点调度 在开始 kiali 亲和性调度之前,先演示一个简单的例子介绍 pod 选择调度到指定 node: 节点打标 使用命令查看当前所有 k8s 节点: [root@k8s-master ~]# ...

  2. 对接口报错404 发现url多了一些不可描述的代码%E2%80%8B

    接口url出现了空格,复制的url可能出现空格肉眼看不出来,手动输入一遍URL

  3. 上班如何优雅的使用idea刷LeetCode(力扣)

    打开idea file->setting ->plugins 搜索 "LeetCode" install "LeetCode editor" 重启后 ...

  4. PPT 转 word

    可以wps  直接转 打开wps   在页面里直接点击右键  可以导出wps

  5. 【Flutter】可滚动组件之滚动控制和监听

    前言 可以用ScrollController来控制可滚动组件的滚动位置. 接口描述 ScrollController({ // 初始滚动位置 double initialScrollOffset = ...

  6. windows打包脚本出现 /bin/sh^M: 坏的解释器: 没有那个文件或目录 错误

    1.错误描述 我在Windows 10 系统下打包dolphinscheduler,上传到centos7解压之后,执行脚本报如下错误: -bash: ./dolphinscheduler-daemon ...

  7. 【JS学习】var let const声明变量的异同点

    [JS学习]var let const声明变量的异同点 前言: 本博客系列为学习后盾人js教程过程中的记录与产出,如果对你有帮助,欢迎关注,点赞,分享.不足之处也欢迎指正,作者会积极思考与改正. 总述 ...

  8. 【Linux】ssh远程连接到指定ip的指定用户上

    通过ssh可以远程连接到其他的机器上,但是如果只想连接到指定的用户的话 需要这样做: -l 选项 (是L不是I,小写) ssh IP -l 用户名 这里的ip如果在hosts下就可以直接输入域名或者主 ...

  9. 攻防世界—pwn—hello_pwn

    题目分析 下载文件后首先使用checksec检查文件保护机制 使用ida查看伪代码 思路明确,让dword_60106C == 1853186401即可输出flag 信息收集 偏移量 sub_4006 ...

  10. ctfhub技能树—文件上传—双写后缀

    双写后缀绕过 用于只将文件后缀名,例如"php"字符串过滤的场合: 例如:上传时将Burpsuite截获的数据包中文件名[evil.php]改为[evil.pphphp],那么过滤 ...