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 ...
随机推荐
- php对表格进行批量操作如全选反选删除功能
<!DOCTYPE> <html> <head> <meta http-equiv="content-type" content=&quo ...
- 【JUC】JDK1.8源码分析之ThreadPoolExecutor(一)
一.前言 JUC这部分还有线程池这一块没有分析,需要抓紧时间分析,下面开始ThreadPoolExecutor,其是线程池的基础,分析完了这个类会简化之后的分析,线程池可以解决两个不同问题:由于减少了 ...
- c#和Javascript中去重总结
一.前言 去重在我们的开发过程中经常遇到,避免重复元素的添加,我们需要对获取到的集合(包括List.Array等) 做相关的过滤操作.确保对象的唯一性,从而达到保证数据不冗余重复.由于自己是做.net ...
- 【原创】技术往事:改变世界的TCP/IP协议(珍贵多图、手机慎点)
1.前言 作为应用层开发人员,接触最多的网络协议通常都是传输层的TCP(与之同处一层的另一个重要协议是UDP协议),但对于IP协议,对于应用程序员来说更多的印象还是IP地址这个东西,再往深一点也就很难 ...
- 生成树形结构的json字符串代码(c#)供前端angular tree使用.
框架是使用EF6.0.可以针对返回的值使用Newtonsoft.Json.dll(百度搜一下)来对返回的值序列化为json字符串,如果对以下值那就是使用JsonConvert.SerializeObj ...
- CSS3学习总结
(写在前边~)过了这么长时间,才写博客,最近实在是太忙了,做了两个项目,一个项目用于练手,自我感觉做的很漂亮,一个项目是一套完整的页面体系,答辩时候老师给了100分和99分,并让我打包上传,我很是感动 ...
- Java 四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor
介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new T ...
- 轻量的、可自定义 CSS 的 Lightbox 相册插件
jQuery LightGallery是一个轻量级的,可定制的,模块化的,响应式的 jQuery 相册插件.它采用 CSS 来实现图像和视频的大小调整.因此,这将是非常灵活的,并且比使用 JavaSc ...
- CSS中详解hight属性
目录结构: // contents structure [-] hight属性值类型一览表 height的%的使用 定义 实例 需要注意的 参考文章 hight属性值类型一览表 value descr ...
- HTML标签界里不会再用到的标签属性(一)
为了成为一名初级前端开发工程师,最近正在探寻HTML标签的众多奥秘,果不其然,让我发现了许多被“冷落”了的标签属性. 一.<!DOCTYPE> 自从HTML5流行之后,<!DOCTY ...