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 ...
随机推荐
- 在IE11下设置SharePoint Server 2013却遇到“需要 Internet Explorer 才能使用此功能。”的解决办法
就在昨天顺利升级到Windows 8.1 随之IE也升级到了IE11,但是当打开IE11设置SharePoint Server 2013的时候遇到了一些小情况: Figure 1使用Windows 8 ...
- 1Z0-053 争议题目解析46
1Z0-053 争议题目解析46 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 46.What happens when you run the SQL Tuning Adviso ...
- 原创:微信小程序入口猜想?
昨天看到一篇文章:是有一个人逆向了微信源码,从中发现了很多关于小程序的未公开内容,然后发布了出来,不过很快作者就删掉了文章,而我也没保留,只是隐约留下来一点点印象,就是作者推测了很多个入口:作者删掉的 ...
- T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll
生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 ,一定要自已新建,把T4代码复制进去,好多人因为用我现成的T4报错(原因不明) 点击添加文 ...
- 【翻译】设计模式学习系列1---【Design Patterns Simplified: Part 1【设计模式简述:第一部分】】
原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part1/ Design Pattern ...
- C# 判断字符串是否是int/double
using System.Text.RegularExpressions; /// <summary> /// 判断字符串是否是int/double /// </summary> ...
- string转byte[]
static byte[] GetBytes(string str) { byte[] bytes = new byte[str.Length * sizeof(char)]; System.Buff ...
- Asp.net mvc返回Xml结果,扩展Controller实现XmlResult以返回XML格式数据
我们都知道Asp.net MVC自带的Action可以有多种类型,比如ActionResult,ContentResult,JsonResult……,但是很遗憾没有支持直接返回XML的XmlResul ...
- 浅谈web网站架构演变过程
前言 我们以javaweb为例,来搭建一个简单的电商系统,看看这个系统可以如何一步步演变. 该系统具备的功能: 用户模块:用户注册和管理 商品模块:商品展示和管理 交易模块:创建交易和管理 阶 ...
- javascript关于继承
上一篇已介绍了组合继承,现在讲讲剩余的几种继承. 原型式继承 调用一个函数,接收这个函数返回来的对象,这个对象的原型就是传入函数的参数对象. 如: function personObject(o){ ...