MySQL备份工具之mysqldump使用
MySQL备份工具之mysqldump使用说明
一、备份分类
根据能否停用数据库,将备份类型分为:
1. 冷备:数据库服务停止后备份
2. 温备:只能对数据库进行读操作,不能进行写操作
3. 热备:在线备份,可以对数据库进行读写操作
根据是直接备份数据库文件还是数据库里面的数据,将备份类型分为:、
1. 物理备份:直接复制数据库文件
2. 逻辑备份:将数据导出到文本文件中
根据备份是备份全部内容还是部分内容,将备份类型分为:
1. 完全备份:full backup,备份全部数据
2. 差异备份:fidderential backup,只备份上次完全备份以来变化的数据
3. 增量备份:incrementl backup,只备份上次完全增量备份以后的数据
注:因此数据库备份策略一般是完全备份+增量备份,或者完全备份+差异备份
二、备份工具
mysqldump:是逻辑备份工具,mysqldump进行温备份,备份时需要加上一个全局锁,客户端只能进行读操作。
mysqlbackup:对于innodb引擎的表mysqlbackup可以进行热备;但是对于非innodb表mysqlbackup就只能温备了。
Xtrabackup:
1.xtrabackup是一种物理备份工具,通过协议连接到mysql服务端,然后读取并复制innodb底层的"数据块",完成所谓的"物理备份"。
2.支持对innodb进行热备、增量备份、差量备份。
3.支持对myisam进行温备,因为在备份myisam表时,会对myisam表添加读锁,而且不能对myisam表进行增量备份,每次备份myisam数据都是全量,即使名义上是增量,但是实际上仍然是全量。
注:innodb引擎热备,myism引擎温备。
三、备份工具mysqldump
常用选项:
--add-drop-database:每个数据库创建之前添加drop数据库语句
-A,--all-databases: Dump all the databases
-B,--databases: --databases db1 db2... 备份指定的多个库
--x,--lock-all-tables:请求锁定所有表之后在备份
-l,--lock-tables:锁定指定的表
--single-transaction:能够对InnoDB存储引擎实现热备
--events:为备份的数据库备份事件
--routines:备份routines(存储过程和函数)
--triggers:为每个备份的表备份trigger
-q,--quick:快速导出,备份时逐行读取表而非一次全部行后缓冲在内存中。在备份大表时有用。
-F,--flush-logs:备份前,请求到锁之后滚动日志
--all-tablespaces,-Y: 备份所有表空间
--force, -f:即使发现sql错误,仍然继续备份
--no-data, -d:只导出表结构
--tables:覆盖 --databases or -B选项,后面所跟参数被视作表名
--add-drop-table:在每个创建数据库表语句前添加删除数据库表的语句
--add-locks:备份数据库表时锁定数据库表;
--comments:添加注释信息;
--compact:压缩模式,产生更少的输出
--complete-insert:输出完成的插入语句
--default-character-set:指定默认字符集
--host:指定要备份数据库的服务器;
--lock-tables:备份前,锁定所有数据库表
--no-create-db:禁止生成创建数据库语句
--no-create-info:禁止生成创建数据库库表语句
--password:连接MySQL服务器的密码
--port:MySQL服务器的端口号
--user:连接MySQL服务器的用户名
--socket,-S:指定连接mysql的socket文件位置
--master-data=[0|1|2]:记录二进制日志文件及位置
0表示不记录
1表示记录change master语句
2记录为注释的change master语句
--opt是quick,add-drop-table,add-locks,extended-insert,lock-tables几个参数的合称,一般都要使用
注:备份和恢复的过程比较慢,很难实现差异或增量备份恢复,如果目标库不存在,需要事先手动创建。
本次实验操作用的是mariadb,默认引擎为innodb
下面用mysqldump工具进行mysql数据库备份操作:
方法一:锁表,滚动日志,备份
MariaDB [(none)]> flush tables with read lock; #锁表,只能读不能写
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> flush logs; #滚动日志
Query OK, 0 rows affected (0.00 sec)
mysqldump -uroot -p123456 --databases zabbix | gzip > /opt/zabbix.sql.gz
方法二:适用于MyISAM存储引擎
mysqldump -uroot -p123456 --database zabbix --lock-all-tables --flush-logs | gzip > /opt/zabbix.sql.gz
方法三:使用于innodb存储引擎,innodb支持热备,mariadb默认支持innodb引擎
mysqldump -uroot -p123456 --database zabbix --single-transaction --flush-logs | gzip > /opt/zabbix.sql.gz
扩展:既然熟悉了mysqldump命令,那么可不可以写一个mysql的备份脚本呢?同时用邮件的方式发送通知给管理员?
总结:mysqldump备份方式是采用的逻辑备份,其最大的缺陷是备份和恢复速度较慢,如果数据库大于50G,mysqldump备份就不太适合。
四、使用mysqldump进行增量备份
MySQL备份工具之mysqldump使用的更多相关文章
- mysql备份工具 :mysqldump mydumper Xtrabackup 原理
备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之百的数据(取决于备份周期),但至少能将损失降到最低.衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(R ...
- MySQL备份--xtrabackup与mysqldump工具使用
MySQL备份----xtrabackup与mysqldump工具的使用 一.Xtrabackup8.0: 一个用于MySQL数据库物理热备的备份工具,支持MySQL.Percona server和M ...
- mysql 备份报错mysqldump: [Warning] Using a password on the command line interface can be insecure.
-------------------------------------------------------------------------------- mysql 备份报错mysqldump ...
- mysql备份工具innobackupex,xtrabackup-2.1的原理和安装
mysql备份工具innobackupex,xtrabackup-2.1的原理和安装 http://bbs.2cto.com/read.php?tid=310496 一.Xtrabackup介绍 1. ...
- Mysql备份工具xtraback全量和增量测试
Mysql备份工具xtraback全量和增量测试 xtrabackup 是 percona 的一个开源项目,可以热备份innodb ,XtraDB,和MyISAM(会锁表) 官方网址http:// ...
- Mysql备份工具比较
Mysql备份工具比较 大 | 中 | 小 [ 2012/12/25 12:10 | by Sonic ] 1. 使用automysqlbackup http://sourceforge.net/pr ...
- Mysql备份工具mysqldump和mysqlhotcopy
(1).Mysql备份类型 1)按照备份时对数据库的影响分为 Hot backup(热备):也叫在线备份.指在数据库运行中直接备份,对正在运行的数据库没有任何影响. Cold backup(冷备):也 ...
- (3.1)mysql备份与恢复之mysqldump
目录: 1.单实例联系 1.1.备份单个数据库联系多种参数使用 [1]mysqldump命令备份演示 [2]查看备份文件 [3]用备份文件还原 1.2.mysqldump 各类参数释义 [1]--de ...
- mysql二进制日志和mysql备份工具介绍以及日志恢复
mysql备份: 三种备份方式 冷备:数据库停机,在进行备份 热备:lock table锁表,read 数据库只可以读不能写,在备份 温备:备份时数据库正常运行 备份类型:完整备份:全部备份,部分 ...
随机推荐
- 【HDU - 4927】Series 1
BUPT2017 wintertraining(15) #5I 题意 输出序列A[1..n]的第n-1阶差分(一个整数). 题解 观察可知答案就是 \[ \sum_{i=0}^{n-1} {(-1)^ ...
- 洛谷P1084 疫情控制(NOIP2012)(二分答案,贪心,树形DP)
洛谷题目传送门 费了几个小时杠掉此题,如果不是那水水的数据的话,跟列队的难度真的是有得一比... 话说蒟蒻仔细翻了所有的题解,发现巨佬写的都是倍增,复杂度是\(O(n\log n\log nw)\)的 ...
- flowable6.4.1+springboot使用dmn
resources/dmn/strings_1.dmn <?xml version="1.0" encoding="UTF-8"?> <def ...
- 【Loj116】有源汇有上下界最大流(网络流)
[Loj116]有源汇有上下界最大流(网络流) 题面 Loj 题解 模板题. #include<iostream> #include<cstdio> #include<c ...
- 【COGS2652】秘术「天文密葬法」(长链剖分,分数规划)
[COGS2652]秘术「天文密葬法」(长链剖分,分数规划) 题面 Cogs 上面废话真多,建议直接拉到最下面看一句话题意吧: 给个树,第i个点有两个权值ai和bi,现在求一条长度为m的路径,使得Σa ...
- centos7搭建ELK Cluster集群日志分析平台(三):Kibana
续 centos7搭建ELK Cluster集群日志分析平台(一) 续 centos7搭建ELK Cluster集群日志分析平台(二) 已经安装好elasticsearch 5.4集群和logst ...
- 随机总数字里面选取随机数字进行随机排序案例(JAVA实现)
随机总数字里面选取随机数字进行随机排序案例,案例如下: 代码code: package com.sec; import java.util.Arrays; import java.util.Scann ...
- Servlet -- 重定向
重定向的两种方式: 1: protected void doGet(HttpServletRequest request, HttpServletResponse response) throws S ...
- express搭建服务器
学习express搭建node服务器 一.安装express框架 1.了解框架(百度) 2.下载框架 (1)使用npm命令下载 npm install express -g //全局安装,安装的是ex ...
- 【UR #3】链式反应
http://uoj.ac/problem/50 %炮姐 好博客 树形结构 枚举根节点的儿子是哪两个 然后列出方程: 然后有EGF的影子! 倍增? 泰勒展开可以把未知数从函数里拿出来!并且变成1次项, ...