MySQL三种备份
一)备份分类
|
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备份工具使用如下:
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_checkpointsbackup_type = full-backupedfrom_lsn = 0to_lsn = 1619068last_lsn = 1619068compact = 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_checkpointsbackup_type = incrementalfrom_lsn = 1619068to_lsn = 1619478last_lsn = 1619478compact = 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.cnfthread_concurrency = 8datadir = /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-snapDo you really want to remove active logical volume mysql-snap? [y/n]: yLogical volume "mysql-snap" successfully removed |
MySQL三种备份的更多相关文章
- 【转】Mysql三种备份详解
一.备份的目的 做灾难恢复:对损坏的数据进行恢复和还原需求改变:因需求改变而需要把数据还原到改变以前测试:测试新功能是否可用 二.备份需要考虑的问题 可以容忍丢失多长时间的数据:恢复数据要在多长时间内 ...
- mysql三种备份方式
一.备份的目的 做灾难恢复:对损坏的数据进行恢复和还原需求改变:因需求改变而需要把数据还原到改变以前测试:测试新功能是否可用 二.备份需要考虑的问题 可以容忍丢失多长时间的数据:恢复数据要在多长时间内 ...
- mysql 三种恢复方式
为了保障数据的安全,需要定期对数据进行备份.备份的方式有很多种,效果也不一样.一旦数据库中的数据出现了错误,就需要使用备份好的数据进行还原恢复.从而将损失降到最低.下面我们来了解一下MySQL常见的有 ...
- MySQL三种存储引擎总结
MySQL三种存储引擎 MyISAM.InnoDB.MEMORY 1.MyISAM MyISAM,3.23.34a前的默认存储引擎. 优缺点 优点 在于占用空间小,处理速度快. 缺点 不支持事务的完整 ...
- mysql三种带事务批量插入
原文:mysql三种带事务批量插入 c#之mysql三种带事务批量插入 前言 对于像我这样的业务程序员开发一些表单内容是家常便饭的事情,说道表单 我们都避免不了多行内容的提交,多行内容保存,自然要用到 ...
- [mysql]三种方法为root账户指定密码
前言:前段时间把mysql安装后一直没管它,当时就在奇怪为什么mysql登陆不要密码,原来一直用的超用户账户登陆的(简称超级用户) 其实只怪自己太无知,之前一直用的phpbydamin进行的数据库的可 ...
- Oracle数据库三种备份方案
Oracle数据库有三种标准的备份方法,它们分别是导出/导入(EXP/IMP).热备份和冷备份.导出备件是一种逻辑备份,冷备份和热备份是物理备份. 一. 导出/导入(Export/Import) 利用 ...
- Linux下SVN的三种备份方式
原文链接:http://blog.csdn.net/windone0109/article/details/4040772 (本文例子基于FreeBSD/Linux实现,windows环境请自己做出相 ...
- MySQL三种InnoDB、MyISAM和MEMORY存储引擎对比
什么是存储引擎? MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力.通过选择不同的技术,你能 ...
随机推荐
- 关于slow http attack以及apche tomcat的应对方式
HTTP 的 Slow Attack 有着悠久历史的 HTTP DOS 攻击方式,最早大约追溯到 5 年前,按理说早该修复了,但是 Apache 的默认配置中仍然没有添加相关配置,或者他们认为这是 f ...
- Zebras CodeForces - 950C(思维)
借鉴自: https://www.cnblogs.com/SuuT/p/8619227.html https://blog.csdn.net/my_sunshine26/article/details ...
- JAVA中的堆、栈等内存分析
在 JAVA 中,有六个不同的地方可以存储数据 1. 寄存器( register ) 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...
- 【BZOJ1951】古代猪文(CRT,卢卡斯定理)
[BZOJ1951]古代猪文(CRT,卢卡斯定理) 题面 BZOJ 洛谷 题解 要求什么很显然吧... \[Ans=G^{\sum_{k|N}{C_N^k}}\] 给定的模数是一个质数,要求解的东西相 ...
- BZOJ5333 [Sdoi2018]荣誉称号 【差分 + 树形dp】
题目链接 BZOJ5333 题解 看到式子,立即想到二叉树上一个点及其\(k\)个父亲权值和[如果有的话]模\(m\)意义下为\(0\) 考虑如何满足条件 我们假设\(1\)号为第\(0\)层 那么我 ...
- opencv2 直方图之calchist函数使用(转)
OpenCV提供了calcHist函数来计算图像直方图. 其中C++的函数原型如下:void calcHist(const Mat* arrays, int narrays, const int* c ...
- Codeforces Round #427 (Div. 2) D dp
D. Palindromic characteristics time limit per test 3 seconds memory limit per test 256 megabytes inp ...
- Java中String的替换函数:replace与replaceAll的区别
例如有如下x的字符串 String x = "[kllkklk\\kk\\kllkk]"; 要将里面的"kk"替换为++,可以使用两种方法得到相同的结果 r ...
- PlantUML —— 应用于 Eclipse 的简单快速的 UML 编辑软件
PlantUML —— 应用于 Eclipse 的简单快速的 UML 编辑软件 简介: 在应用系统软件开发过程中,如果软件由很多对象组成,它的结构仅仅凭借分析很难理清,同时为了有利于软件的开发及重用, ...
- 前端PHP入门-002-安装WAMP的集成环境md
> 第一次讲PHP,让我感觉还是满好玩的,一种新的知识的学习,需要我们努力! > 这次PHP课程计划是15天快速入门的课程! 只是单独的讲PHP语言,不涉及很深的内容,只是想让web前端的 ...