Mysql备份工具mysqldump和mysqlhotcopy
(1).Mysql备份类型
1)按照备份时对数据库的影响分为
Hot backup(热备):也叫在线备份。指在数据库运行中直接备份,对正在运行的数据库没有任何影响。
Cold backup(冷备):也叫离线备份。指在数据库停止的情况下备份。
Warm backup(温备):在数据库运行时备份,会加一个全局锁以保证数据的一致性,会对当前数据库的操作有影响。
2)按照备份后的文件内容分为
逻辑备份:指备份后的文件内容是可读的,通常为文本文件,内容一般是SQL语句或表内的实际数据(mysqldump和select * into outfile),一般适用于数据库的升级和迁移,还原时间较长。
裸文件备份:也叫物理备份。拷贝数据库的物理文件,数据库既可以处于运行状态(mysqlhotcopy、ibbackup、xtrabackup一类工具),也可以处于停止状态,还原时间较短。
3)按照备份数据库的内容分为
完全备份:对数据库进行完整的备份。
增量备份:在上一次完整备份的基础上,对更新的数据进行备份(xtrabackup)
日志备份:二进制日志备份,主从同步。
(2).mysqldump
mysqldump是逻辑备份工具,支持MyISAM和InnoDB引擎。数据库运行时,MyISAM引擎只支持温备,InnoDB支持热备和温备。
1)导出数据
导出所有数据库
[root@youxi1 ~]# mysqldump -uroot -p123456 -A > all.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# mysqldump -uroot -p123456 --all-databases > all2.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll all.sql all2.sql
-rw-r--r-- 1 root root 773437 6月 14 13:52 all2.sql
-rw-r--r-- 1 root root 773437 6月 14 13:51 all.sql
导出指定数据库里的所有数据表
[root@youxi1 ~]# mysqldump -uroot -p123456 mysql > mysql.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll mysql.sql
-rw-r--r-- 1 root root 1089455 6月 14 13:53 mysql.sql
导出指定数据库里的指定数据表
[root@youxi1 ~]# mysqldump -uroot -p123456 test_db user_tb > user.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll user.sql
-rw-r--r-- 1 root root 1883 6月 14 13:54 user.sql
只导出指定数据库里的所有数据表的表结构
[root@youxi1 ~]# mysqldump -uroot -p123456 -d test_db > test_db_table.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll test_db_table.sql
-rw-r--r-- 1 root root 1618 6月 14 13:56 test_db_table.sql
只导出数据库里的所有数据表的所有数据
[root@youxi1 ~]# mysqldump -uroot -p123456 -t test_db > test_db_data.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll test_db_data.sql
-rw-r--r-- 1 root root 1513 6月 14 13:57 test_db_data.sql
导出指定数据库的所有内容
[root@youxi1 ~]# mysqldump -uroot -p123456 -B test_db > test_db.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@youxi1 ~]# ll test_db.sql
-rw-r--r-- 1 root root 2029 6月 14 14:02 test_db.sql
注意:以上几个实例,只有-A、--all-databases和-B选项有创建数据库,并使用数据库的语句。这和后面的导入数据息息相关。
2)导入数据
如果使用-A、--all-databases和-B选项导出的数据库可以使用mysql直接导入
mysql -uroot -p123456 < all.sql
如果不是则需要进入到mysql内部,选择数据库才能导入数据;或者使用mysql时指定数据库
>use mysql
>source mysql.sql mysql -uroot -p123456 mysql < mysql.sql
(3).mysqlhotcopy
mysql5.7已经没有这个命令了,多用于mysql5.5之前。mysqlhotcopy使用lock tables、flush tables和cp或scp来快速备份数据库或单个表,属于裸文件备份(物理备份),只能用于MyISAM引擎的数据库。本质是使用锁表语句,然后cp或scp。
可以使用yum命令安装
yum -y install perl-DBD*;
1)备份
备份一个数据库到目标目录
mysqlhotcopy -u [用户名] -p [密码] [数据库名] [目标目录]
备份多个数据库到目标目录
mysqlhotcopy -u [用户名] -p [密码] [数据库名1 数据库名2...] [目标目录]
备份数据库中的某个表到指定目录
mysqlhotcopy -u [用户名] -p [密码] [数据库名]./[表名]/ [目标目录]
2)还原
在Linux中Mysql数据库都是以物理文件存在的,数据库对应的是目录。如果想要还原只要将原来的文件拷贝回原目录即可。
单个数据库备份还原方式:如果文件所有这和所属组不是mysql,请使用chown修改。
cp -ra [目标目录] /var/lib/mysql/[数据库名]/
(4).mysqldump和mysqlhotcopy比较
1.mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,数据库大时,占用系统资源较多,支持常用的MyISAM,innodb引擎;mysqlhotcopy只是简单的缓存写入和文件复制的过程,占用资源和备份速度比mysqldump快很多很多,特别适合大的数据库,但需要注意的是:mysqlhotcopy只支持MyISAM 引擎。
2.mysqlhotcopy只能运行在数据库目录所在的机器上,mysqldump可以用在远程客户端。
3.mysqlhotcopy恢复只需要拷贝备份文件到源目录覆盖即可,mysqldump需要导入SQL文件到原来库中。
4.两者都在线执行lock tables(锁表)以及unlock tables(解锁表)。
Mysql备份工具mysqldump和mysqlhotcopy的更多相关文章
- mysql备份工具 :mysqldump mydumper Xtrabackup 原理
备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之百的数据(取决于备份周期),但至少能将损失降到最低.衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(R ...
- MySQL备份工具之mysqldump使用
MySQL备份工具之mysqldump使用说明 一.备份分类 根据能否停用数据库,将备份类型分为: 1. 冷备:数据库服务停止后备份 2. 温备:只能对数据库进行读操作,不能进行写操作 3. 热备:在 ...
- MySQL数据备份之逻辑备份工具mysqldump
#前言:我们知道对数据进行备份很重要,出现非正常操作可以进行对数据进行恢复,下面我们就来使用一下mysql数据库自带的一个逻辑备份工具mysqldump 1.简单概述 #mysqldump:mysql ...
- 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在slave 上进行备份
MySQL 备份脚本--mysqldump在slave 上进行备份 使用mysqldump在slave上进行备份,建议使用stop slave sql_thread,start slave sql_t ...
- MySQL备份还原——mysqldump工具介绍
mysqldump是一款MySQL逻辑备份的工具,他将数据库里面的对象(表)导出成SQL脚本文件.有点类似于SQL SEVER的"任务-生成脚本"的逻辑备份功能.mysqldump ...
- Mysql 备份恢复之 Mysqldump 工具
目前正在学习中,看到mysqldump工具导出的数据都是文本形式的,如果是blob或text大对象类型导出的是什么格式的?这个需要后续研究.下面只先总结下简单的. 一.备份1.备份Mysql一个数据库 ...
随机推荐
- Using Microsoft Visual C++ DLLs with C++Builder
Using Microsoft Visual C++ DLLs with C++Builder As powerful as C++Builder is, the majority of DLLs d ...
- css全局定位内容图片自动居中
最近在做一个资讯站点时候,因为采集的数据,图片不居中,导致界面很不美观,所以需要全局定义下图片输出时候进行居中. .content img { max-width:800px;_width:expre ...
- python 正则表达式特殊字符
字符 描述 \ 将下一个字符标记为一个特殊字符.或一个原义字符.或一个 向后引用.或一个八进制转义符.例如,'n' 匹配字符 "n".'\n' 匹配一个换行符.序列 '\\' 匹配 ...
- jquery.lazyload(懒加载)的使用与配置
jquery lazyload是一款基于jquery框架的图片延迟加载应用,它可以让用户访问页面的时候只显示当前屏幕所示的图片.原理为利用JS替换图片src为loading图片,新data-origi ...
- 29、[源码]-AOP原理-AnnotationAwareAspectJAutoProxyCreatovi
29.[源码]-AOP原理-AnnotationAwareAspectJAutoProxyCreatovi
- 第十三章 使用ADO.NET访问数据库
一,什么是ADO.NET ADO.NET 是一种以面向对象的设计方法构建的数据访问和操作的类库,它建立在.NET平台上,以便于操作各种各样的数据源.这些数据源可以是数据库, 也可以是文本文件 ,EXC ...
- 学到了林海峰,武沛齐讲的Day25-完
@property @classmethod @staticmethod 类的继承
- 爬虫(七):爬取猫眼电影top100
一:分析网站 目标站和目标数据目标地址:http://maoyan.com/board/4?offset=20目标数据:目标地址页面的电影列表,包括电影名,电影图片,主演,上映日期以及评分. 二:上代 ...
- VMware安装Centos7超详细教程
本篇文章主要介绍了VMware安装Centos7超详细过程(图文),具有一定安装参考价值 在没有运维的情况下,很多时候测试需要自己搭建测试环境,而测试环境又分为QA环境,自动化测试环境,uat环境,以 ...
- Mac下的PHP的配置与运行
mac 下自带apache bogon:Documents macname$ apachectl -version Server version: Apache/ (Unix) Server buil ...