一)备份分类

1
2
3
4
5
6
7
8
9
10
11
12
冷备:cold backup数据必须下线后备份
温备:warm backup全局施加共享锁,只能读,不能写
热备:hot backup数据不离线,读写都能正常进行
备份的数据集
完全备份:full backup
部分备份:partial backup
备份时的接口(是直接备份数据文件还是通过mysql服务器导出数据)
物理备份:直接复制(归档)数据文件的备份方式:physical backup
逻辑备份:把数据从库中提出来保存为文本文件:logical backup
完全备份:full backup
增量备份:incrementl backup
差异备份:fidderential backup

二)备份工具mysqldump讲解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
mysqldump:逻辑备份工具
InnoDB引擎热备,MyISM温备,Aria温备
备份和恢复的过程比较慢,很难实现差异或增量备份
恢复时,如果目标库不存在,需要事先手动创建
常用选项:
--all-databases:备份所有库
--databases db1 db2...:备份指定的多个库
注意:备份前要加锁:
--lock-all-tables:请求锁定所有表之后在备份。
--lock-tables:锁定指定的表。
--single-transaction:能够对InnoDB存储引擎实现热备。
备份代码:
--events:备份事件调度器代码
--routines:备份存储过程和存储函数
--triggers:备份触发器
备份时滚动日志:
--flush-logs:备份前,请求到锁之后滚动日志。
复制时的同步位置标记
--master-data=【0|1|2
0表示不记录
1表示记录change master语句
2记录为注释的change master语句
使用mysqldump备份:
请求锁:--lock-all-tables或使用--singe-transaction进行innoDB热备
滚动日志:--flush-logs
选定要备份的库:--databases
记录二进制日志文件及位置:--master-data=0|1|2

mysqldump三种备份方式:

第一种:

备份:[root@station141 ~]# mysqldump --databases benet > /tmp/benet.sql

mysql> unlock tables;解锁

mysql> drop database benet;删除库
Query OK, 1 row affected (0.70 sec)

恢复

第二种方式备份:

mysqldump --databases benet --lock-all-tables --flush-logs > /tmp/benet.sql直接备份的

第三种方式备份:主要是针对innoDB引擎备份,实现热备。

mysqldump --databases benet --single-transactions --flush-logs > /tmp/benet.3.sql

备份所有数据库

mysqldump --all-databases > /tmp/all.sql

Xtrabackup备份工具使用如下:

下载位置:http://www.percona.com/

yum -y install percona-xtrabackup-2.1.8-733.rhel6.x86_64.rpm

yum -y install percona-toolkit-2.2.7-1.noarch.rpm

备份全部数据库:

innobackupex --user=root /myback

1
2
3
4
5
6
[root@localhost 2014-04-14_23-39-44]# cat xtrabackup_checkpoints
backup_type = full-backuped
from_lsn = 0
to_lsn = 1619068
last_lsn = 1619068
compact = 0

恢复数据库

innobackupex --apply-log /mydata/2014-04-14_23-39-44/先把数据整理出来
innobackupex --copy-back /mydata/2014-04-14_23-39-44/根据全备份恢复数据

做增量备份

innobackupex --incremental /mydata/ --incremental-basedir=/mydata/2014-04-14_23-39-44/

基于上次的全备做

1
2
3
4
5
6
[root@localhost 2014-04-14_23-45-11]# cat xtrabackup_checkpoints
backup_type = incremental
from_lsn = 1619068
to_lsn = 1619478
last_lsn = 1619478
compact = 0

查看是增量备份

恢复增量备份,依次先恢复,全备,后增量

1
2
3
4
innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/
innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/ --incremental-dir=/mydata/2014-04-14_23-45-11/
innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/ --incremental-dir=/mydata/2014-04-14_23-49-01/
innobackupex --copy-back /mydata/2014-04-14_23-39-44/

LVM-snapshot:基于lvm快照备份

大致步骤:

1)事务日志跟数据文件必须在同一个卷上

2)创建快照卷之前,要请求mysql的全局锁,在快照创建完成之后释放锁

3)请求全局锁完成之后,做一次日志滚动;做二进制日志及位置标记(手动进行);

1
2
3
4
5
6
7
8
9
10
11
12
13
[root@localhost ~]# mount
/dev/mapper/vg0-root on / type ext4 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw)
/dev/sda1 on /boot type ext4 (rw)
/dev/mapper/vg0-usr on /usr type ext4 (rw)
/dev/mapper/vg0-var on /var type ext4 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
/dev/mapper/myvg-lvmy on /mnt type ext4 (rw)
/mnt下放的就是mysql数据库得数
1
2
3
[root@localhost ~]# vim /etc/my.cnf
thread_concurrency = 8
datadir = /mnt

安装数据库的时候先创建好个逻辑卷,安装目录为/mnt下。

请求全局锁,滚动日志

MariaDB [(none)]> flush tables with read lock;

MariaDB [(none)]> flush logs;

记录二进制日志位置

mysql -e 'show master status' > mysql.txt

创建快照

[root@localhost ~]# lvcreate -L 1G -s -n mydata-snap -p r /dev/myvg/mydata

解锁

MariaDB [(none)]> unlock tables;

挂载快照并且备份

mount /dev/myvg/mysql-snap /media/

tar -Jcf /tmp.mysq.tar.xz /media/*

卸载并删除快照

1
2
3
4
[root@localhost ~]# umount /media/
[root@localhost ~]# lvremove /dev/myvg/mysql-snap
Do you really want to remove active logical volume mysql-snap? [y/n]: y
Logical volume "mysql-snap" successfully removed

MySQL三种备份的更多相关文章

  1. 【转】Mysql三种备份详解

    一.备份的目的 做灾难恢复:对损坏的数据进行恢复和还原需求改变:因需求改变而需要把数据还原到改变以前测试:测试新功能是否可用 二.备份需要考虑的问题 可以容忍丢失多长时间的数据:恢复数据要在多长时间内 ...

  2. mysql三种备份方式

    一.备份的目的 做灾难恢复:对损坏的数据进行恢复和还原需求改变:因需求改变而需要把数据还原到改变以前测试:测试新功能是否可用 二.备份需要考虑的问题 可以容忍丢失多长时间的数据:恢复数据要在多长时间内 ...

  3. mysql 三种恢复方式

    为了保障数据的安全,需要定期对数据进行备份.备份的方式有很多种,效果也不一样.一旦数据库中的数据出现了错误,就需要使用备份好的数据进行还原恢复.从而将损失降到最低.下面我们来了解一下MySQL常见的有 ...

  4. MySQL三种存储引擎总结

    MySQL三种存储引擎 MyISAM.InnoDB.MEMORY 1.MyISAM MyISAM,3.23.34a前的默认存储引擎. 优缺点 优点 在于占用空间小,处理速度快. 缺点 不支持事务的完整 ...

  5. mysql三种带事务批量插入

    原文:mysql三种带事务批量插入 c#之mysql三种带事务批量插入 前言 对于像我这样的业务程序员开发一些表单内容是家常便饭的事情,说道表单 我们都避免不了多行内容的提交,多行内容保存,自然要用到 ...

  6. [mysql]三种方法为root账户指定密码

    前言:前段时间把mysql安装后一直没管它,当时就在奇怪为什么mysql登陆不要密码,原来一直用的超用户账户登陆的(简称超级用户) 其实只怪自己太无知,之前一直用的phpbydamin进行的数据库的可 ...

  7. Oracle数据库三种备份方案

    Oracle数据库有三种标准的备份方法,它们分别是导出/导入(EXP/IMP).热备份和冷备份.导出备件是一种逻辑备份,冷备份和热备份是物理备份. 一. 导出/导入(Export/Import) 利用 ...

  8. Linux下SVN的三种备份方式

    原文链接:http://blog.csdn.net/windone0109/article/details/4040772 (本文例子基于FreeBSD/Linux实现,windows环境请自己做出相 ...

  9. MySQL三种InnoDB、MyISAM和MEMORY存储引擎对比

    什么是存储引擎? MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力.通过选择不同的技术,你能 ...

随机推荐

  1. Liunx 和 Win中的软链接详解

    用过Linux的朋友都知道linux中有软链接的概念,可以通过ln命令创建到目录或文件的软链接,软链接的好处就是可以让一个目录或文件有多个入口但保持单一物理位置,方便应用和管理.    1.命令格式: ...

  2. P2475 [SCOI2008]斜堆

    题目背景 四川2008NOI省选 题目描述 斜堆(skew heap)是一种常用的数据结构.它也是二叉树,且满足与二叉堆相 同的堆性质:每个非根结点的值都比它父亲大.因此在整棵斜堆中,根的值最小. 但 ...

  3. 深入理解JVM一垃圾回收器

    上一篇我们介绍了常见的垃圾回收算法,不同的算法各有各的优缺点,在JVM中并不是单纯的使用某一种算法进行垃圾回收,而是将不同的垃圾回收算法包装在不同的垃圾回收器当中,用户可以根据自身的需求,使用不同的垃 ...

  4. BZOJ2208:[JSOI2010]连通数——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=2208 floyd压位是神马东西…… 我们tarjan缩点之后反向拓扑就可以记录联通块可达状态,然后 ...

  5. 洛谷 P1501 [国家集训队]Tree II 解题报告

    P1501 [国家集训队]Tree II 题目描述 一棵\(n\)个点的树,每个点的初始权值为\(1\).对于这棵树有\(q\)个操作,每个操作为以下四种操作之一: + u v c:将\(u\)到\( ...

  6. 解题:CTSC 2017 吉夫特

    题面 首先有个结论:$C_n^m$为奇数当且仅当$m$是$n$的一个子集 于是从后往前推,记录每个数出现的位置,然后对每个位置枚举子集统计在它后面的贡献即可 #include<cstdio> ...

  7. 解题:SCOI 2008 天平

    题面 我们很容易想到差分约束,但是我们建出来图之后好像并不好下手,因为我们只能得到砝码间的大小关系,并不能容易地得到每个砝码的具体重量. 于是我们有了一种神奇的思路:既然得不到具体重量我们就不求具体重 ...

  8. 那些你不常用却非常有用的MySql语句和命令

    操作数据库 关于数据库的操作比较少,主要是:看.建.用.删. 查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. 1 mysql> show da ...

  9. 4.redis设计与实现--跳跃表

    1.跳跃表由两个结构体构成: 2.总结:

  10. Codeforces 221 A. Little Elephant and Function

    A. Little Elephant and Function time limit per test 2 seconds memory limit per test 256 megabytes in ...