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 数据库只可以读不能写,在备份 温备:备份时数据库正常运行 备份类型:完整备份:全部备份,部分 ...
随机推荐
- Python FAQ
1.在函数a中又定义了函数sum,内部函数sum可以引用外部函数a的参数n,不能这样写n=n+1,两个会出错,这样写s=s+n可以 解决: def a(): n = 1 def sum(): nonl ...
- IDEA中Maven项目使用Junit4单元测试的写法
IDEA默认是安装了junit控件的,直接使用就好了 在maven项目的pom.xml文件中添加依赖 <dependency> <groupId>junit</group ...
- 让$this->error()返回json配置
// 表单请求类型伪装变量'var_method' => '_method',// 表单ajax伪装变量'var_ajax' => '自定义',// 表单pjax伪装变量'var_pjax ...
- Jeesite 代码生成
1.mysql数据库建表 参考自带的sys_area 的创表SQL复制来修修改改即可 2.配置代码生成文件覆盖路径 打开eclipse 按ctrl+shift+R 找到jeesite.propert ...
- #509. 「LibreOJ NOI Round #1」动态几何问题
下面给出部分分做法和满分做法 有一些奇妙的方法可以拿到同样多的分数,本蒟蒻只能介绍几种常见的做法 如果您想拿18分左右,需要了解:质因数分解 如果您想拿30分左右,需要了解:一种较快的筛法 如果您想拿 ...
- VS code golang 开发环境搭建
安装go (1)下载go安装程序 下载地址:https://golang.org/dl/(墙内下载地址http://www.golangtc.com/download),如果是您的系统是windows ...
- hbuilder 个推 问题记录
截止版本日期: 2017/09/19 一,安卓没有角标问题: Android - 2.2+ (支持): 目前仅支持小米(MIUI v5),其它设备调用后无任何效果.官方文档 二,ios角标混乱问题: ...
- C# Socket的安全关闭
网络编程中,socket的安全关闭方法 /// <summary> /// Close the socket safely. /// </summary> /// <pa ...
- 计算机基础:计算机网络-chapter5 运输层
一.运输层做什么事情,通过什么协议实现, 运输层做什么 为相互通信的应用提供逻辑通信 通过端口号来确定应用,提供端到端的服务: 为什么需要运输层,IP层不是就实现了传输数据吗 从IP层来说,是两台主机 ...
- Unity 着色器
Unity中定义了很多种Shader类型,同样的Shader类型我们可以自定义,需要用到ShaderLab着色语言. 一个3D图形是怎样显示在我们的视觉? 3D数据文件-----3D显示程序----- ...