MySQL备份还原——mysqldump工具介绍
mysqldump是一款MySQL逻辑备份的工具,他将数据库里面的对象(表)导出成SQL脚本文件。有点类似于SQL SEVER的“任务-生成脚本”的逻辑备份功能。mysqldump是比较常用的备份方法,适合于在不同MySQL版本之间的迁移、升级。不足之处就是数据库比较大时,mysqldump的效率不高。
mysqldump的主要参数收集整理注释如下,如果你要查看mysqldump的具体参数信息,可以使用命令mysqldump –help
--add-drop-table :在每个创建数据库表语句前添加删除数据库表的语句;
--add-locks :备份数据库表时锁定数据库表;
--all-databases :备份MySQL服务器上的所有数据库;
--comments :添加注释信息;
--compatible=name :它告诉 mysqldump,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容。值可以为ansi、mysql323、mysql40、 postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options等,要使用几个值,用 逗号将它们隔开。当然了,它并不保证能完全兼容,而是尽量兼容。
--compact :压缩模式,产生更少的输出;
--complete-insert,-c :输出完成的插入语句;导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行。这么做能提高插入效 率,但是可能会受到 max_allowed_packet 参数的影响而导致插入失败。因此,需要谨慎使用该参数。
--databases :指定要备份的数据库;
--default-character-set:指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么导出时必须指定该选项,否则再次导入 数据后将产生乱码问题。
--disable-keys :告诉 mysqldump 在 INSERT 语句的开头和结尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 语句,这能大大提高插入语句的速度
--extended-insert :默认情况下,mysqldump 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,设定它的值为 false 即可。
--force :当出现错误时仍然继续备份操作;
--host :指定要备份数据库的服务器;
--hex-blob :使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用本选项。影响到的字段类型有 BINARY、VARBINARY、 BLOB。
--lock-all-tables,-x :在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single- transaction 和 --lock-tables 选项。
--lock-tables :它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表, 如果是 Innodb 表可以用 --single-transaction 选项。;
--no-create-db :禁止生成创建数据库语句;
--no-create-info :禁止生成创建数据库库表语句;
--no-data,-d :不导出任何数据,只导出数据库表结构。
--password :连接MySQL服务器的密码;
--port :MySQL服务器的端口号;
--quick,-q :该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。
--routines,-R : 导出存储过程以及自定义函数。
--single-transaction : 该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用 于事务表,例如 InnoDB 和 BDB。本选项和 --lock-tables 选项是互斥的,因为 LOCK TABLES 会使任何挂起的事务隐含提交。
要想导出大表的话,应结合使用 --quick 选项。
--triggers :同时导出触发器。该选项默认启用,用 --skip-triggers 禁用它。
--user :连接MySQL服务器的用户名
另外关于mysqldump的一些参数默认值如下所示
Variables (--variable-name=value)
and boolean options {FALSE|TRUE} Value (after reading options)
--------------------------------- ----------------------------------------
all-databases FALSE
all-tablespaces FALSE
no-tablespaces FALSE
add-drop-database FALSE
add-drop-table TRUE
add-drop-trigger FALSE
add-locks TRUE
allow-keywords FALSE
apply-slave-statements FALSE
bind-address (No default value)
character-sets-dir (No default value)
comments TRUE
compatible (No default value)
compact FALSE
complete-insert FALSE
compress FALSE
create-options TRUE
databases FALSE
debug-check FALSE
debug-info FALSE
default-character-set utf8
delayed-insert FALSE
delete-master-logs FALSE
disable-keys TRUE
dump-slave 0
events FALSE
extended-insert TRUE
fields-terminated-by (No default value)
fields-enclosed-by (No default value)
fields-optionally-enclosed-by (No default value)
fields-escaped-by (No default value)
flush-logs FALSE
flush-privileges FALSE
force FALSE
hex-blob FALSE
host (No default value)
include-master-host-port FALSE
insert-ignore FALSE
lines-terminated-by (No default value)
lock-all-tables FALSE
lock-tables TRUE
log-error (No default value)
master-data 0
max-allowed-packet 25165824
net-buffer-length 1046528
no-autocommit FALSE
no-create-db FALSE
no-create-info FALSE
no-data FALSE
order-by-primary FALSE
port 0
quick TRUE
quote-names TRUE
replace FALSE
routines FALSE
set-charset TRUE
single-transaction FALSE
dump-date TRUE
socket (No default value)
secure-auth TRUE
ssl FALSE
ssl-ca (No default value)
ssl-capath (No default value)
ssl-cert (No default value)
ssl-cipher (No default value)
ssl-key (No default value)
ssl-crl (No default value)
ssl-crlpath (No default value)
ssl-verify-server-cert FALSE
tab (No default value)
triggers TRUE
tz-utc TRUE
user (No default value)
verbose FALSE
where (No default value)
plugin-dir (No default value)
default-auth (No default value)
mysqldump提供了非常丰富的参数选项、备份非常方便灵活,可以备份所有数据库, 也可以只备份某一个或几个数据库,也可以只备份数据库中的单个或几个表、也可以只备份数据库的表结构......
Usage: mysqldump [OPTIONS] database [tables]
OR mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
OR mysqldump [OPTIONS] --all-databases [OPTIONS]
1: 导出单个数据库
[root@DB-Server ~]# mysqldump -u root -p --default-character-set=utf8 --opt --extended-insert=false test > db_backup_test.sql
Enter password:
2:导出所有数据库
[root@DB-Server ~]# mysqldump -u root -p --default-character-set=utf8 --opt --extended-insert=false --all-databases > db_backup_all.sql;
Enter password:
3:导出指定数据库
[root@DB-Server ~]# mysqldump -u root -p --default-character-set=utf8 --opt --extended-insert=false --databases test mysql > db_backup.sql
Enter password:
4:导出表person
[root@DB-Server ~]# mysqldump -u root -p --default-character-set=utf8 --opt --extended-insert=false test person >db_backup_t_persons.sql
Enter password:
下面介绍一个使用mysqldump备份的shell脚本:mysql_dump_backup.sh
#!/bin/sh
################### mysql_dump_backup.sh: Backup MYSQL Database using mysqldump##################
# Set Variable for Script
# Please change the Location and username and password
# MYSQL Account should have SHOW DATABASES, SELECT, LOCK TABLE, RELOAD Privileges
# ###############################################################################################
DATE=$(date +%Y-%m-%d)
FILENAME="backup_db_all.sql"
LOCATION="/u04/mysqlbackup/"
#DBSERVER=127.0.0.1
USERNAME="root"
PASSWORD="******"
RETENSION=7
################################## Command for MYSQL Dump########################################
########################################## Create Folder#########################################
BACKUPLOCATION="$LOCATION/$DATE"
test ! -d $LOCATION && mkdir $LOCATION
test ! -d $BACKUPLOCATION && mkdir $BACKUPLOCATION
# Collect All Database Name and Dump Each Database to sql Files
#for db in $(mysql --user=$USERNAME --password=$PASSWORD -e 'SHOW DATABASES' -s --skip-column-names); do
# mysqldump --user=$USERNAME --password=$PASSWORD $db | gzip > "$BACKUPLOCATION/$db.$FILENAME.gz";
# DATESTAMP=$(date +%Y-%m-%d);
# TIMESTAMP=$(date +%H:%M:%S);
# echo "$DATESTAMP $TIMESTAMP : $db has been backed up in gzip format" >> "$LOCATION/history.log";
#done
# Collect All Database Name and Dump Whole Database
mysqldump --user=$USERNAME --password=$PASSWORD --all-databases --events --routines --master-data=2 --flush-logs --lock-all-tables | gzip > "$BACKUPLOCATION/$FILENAME.gz"
DATESTAMP=$(date +%Y-%m-%d)
TIMESTAMP=$(date +%H:%M:%S)
echo "$DATESTAMP $TIMESTAMP : All databases have been backed up in gzip format" >> "$LOCATION/history.log";
# Clean Up for Folders Created X Days Ago
FOLDERS=$(find $LOCATION* -type d -mtime +$RETENSION -print0)
for FOLDER in $FOLDERS; do
echo "$DATESTAMP $TIMESTAMP : $FOLDER has been deleted" >> "$LOCATION/history.log";
rm -rf $FOLDER;
done
mysql_log_backup.sh
#!/bin/sh
# mysql-backup-daily.sh: Backup MYSQL Database using mysqldump
# Set Variable for Script
# Please change the Location and username and password
# MYSQL Account should have SHOW DATABASES, SELECT, LOCK TABLE, RELOAD Privileges
# ================================================================================
#DBSERVER=127.0.0.1
USERNAME="root"
PASSWORD="*****"
LOCATION=""/var/lib/mysql/"
BKLOCATION="/u04/mysqlbackup/"
# Command for MYSQL Bin Log Flush
# ======================
# Collect All Database Name and Dump Whole Database
mysql --user=$USERNAME --password=$PASSWORD -e 'FLUSH LOGS' -s
cp $LOCATION/mysql-bin.* $BKLOCATION
参考资料:
http://www.imysql.cn/mysql_backup_and_recover
MySQL备份还原——mysqldump工具介绍的更多相关文章
- Mysql 备份恢复之 Mysqldump 工具
目前正在学习中,看到mysqldump工具导出的数据都是文本形式的,如果是blob或text大对象类型导出的是什么格式的?这个需要后续研究.下面只先总结下简单的. 一.备份1.备份Mysql一个数据库 ...
- (4.12)mysql备份还原——mysql逻辑备份之mysqldump
关键词:mysql逻辑备份介绍,mysqldump,mysqldump最佳实践 我的相关文章:https://www.cnblogs.com/gered/p/9721696.html 正文 1.mys ...
- (4.8)mysql备份还原——binlog查看工具之show binlog的使用
(4.8)mysql备份还原——binlog查看工具之mysqlbinlog及show binlog的使用 关键词:show binlog,mysql binlog查看,二进制文件查看,binlog查 ...
- (4.3)mysql备份还原——mysql备份策略
(4.3)mysql备份还原——mysql备份策略 1.指定备份策略时需要考虑的点 [1.1]备份周期:2次备份间隔时长 [1.2]备份方式:在备份周期中,使用什么备份方式.备份模式 [1.3]实现方 ...
- (4.5)mysql备份还原——深入解析二进制日志(1)binlog的3种工作模式与配置
(4.5)mysql备份还原——深入解析二进制日志(binlog) 关键词:二进制日志,binlog日志 0.建议 (1)不建议随便去修改binlog格式(数据库级别) (2)binlog日志的清理 ...
- (4.1)mysql备份还原——mysql常见故障
(4.1)mysql备份还原——mysql常见故障 1.常见故障类型 在数据库环境中,常见故障类型: 语句失败,用户进程失败,用户错误 实例失败,介质故障,网络故障 其中最严重的故障主要是用户错误和介 ...
- MySQL 备份脚本--mysqldump在slave 上进行备份
MySQL 备份脚本--mysqldump在slave 上进行备份 使用mysqldump在slave上进行备份,建议使用stop slave sql_thread,start slave sql_t ...
- (4.14)mysql备份还原——mysql物理热备工具之ibbackup
关键词:mysql热备工具,ibbackup,mysql物理备份工具 1. 准备 ibbackup 是 InnoDB 提供的收费工具,它支持在线热备 InnoDB 数据,主要有以下特性: * Onli ...
- MySQL备份还原——AutoMySQLBackup介绍
AutoMySQLBackup是一个开源的MySQL备份脚本.可以说它是一个轻量级的备份方案,AutoMySQLBackup的安装.配置非常简单.方便.AutoMySQLBackup的sourcefo ...
随机推荐
- 小菜学习设计模式(二)—单例(Singleton)模式
前言 设计模式目录: 小菜学习设计模式(一)—模板方法(Template)模式 小菜学习设计模式(二)—单例(Singleton)模式 小菜学习设计模式(三)—工厂方法(Factory Method) ...
- php对表格进行批量操作如全选反选删除功能
<!DOCTYPE> <html> <head> <meta http-equiv="content-type" content=&quo ...
- iOS开发——高级特性&Runtime运行时特性详解
Runtime运行时特性详解 本文详细整理了 Cocoa 的 Runtime 系统的知识,它使得 Objective-C 如虎添翼,具备了灵活的动态特性,使这门古老的语言焕发生机.主要内容如下: 引言 ...
- mysql转换类型
今天遇到一个问题,那就是当时一个项目设计表的时候,把时间以20160101123596这样的形式,以varchar存到了数据库里. 今天要写一条sql,查询一个报表,条件就是要过滤这个时间,但是var ...
- Final Cut Pro X效果插件开发总结
一.介绍 最近公司需要针对Final Cut Pro(FCP)开发一款效果插件,用于对公司自己开发的视频格式进行后期处理.Final Cut Pro是苹果公司推出的一款视频剪辑软件,因此需要在OSX平 ...
- JsTree实现简单的CRUD
现在需要将省市县区域这块搞成树状图的形状,由于项目使用的AngularJS+ABP+WebAPI各个模块之间数据传输形式是json格式,那么对于JsTree来说就方便很多了,只需要将json数据搞成我 ...
- Rafy 领域实体框架 - 领域模型设计器(建模工具)设计方案
去年4月,我们为 Rafy 框架添加了领域模型设计器组件.时隔一年,谨以本文,简要说明该领域模型设计器的设计思想. 设计目标 Rafy 实体框架中以领域驱动设计作为指导思想.所以在开发时,以领域建模为 ...
- Oracle学习总结_day05_集合_连接查询
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! day05_集合_连接查询 集合操作符 UNION ( ...
- yii的入口文件index.php中为什么会有这两句
yii的应用模板中,index.php中 前面会有这两句 <?php // comment out the following two lines when deployed to produc ...
- 转载:《TypeScript 中文入门教程》 17、注解
版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 随着TypeScript和ES6里引入了类,现在在一些场景下我们会需要额外的特性 ...