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 ...
随机推荐
- WebSocket 介绍(一)
WebSocket 发起单个请求,服务端不需要等待客服端,客户端在任何时候也能发消息到服务端,减少了轮询时候的延迟.经历一次连接后,服务器能给客户端发多次.下图是轮询与WebSocket的区别. 基于 ...
- effective java 读后感
think in java , effective java 这两本书一直都在java的生态圈中经久不衰.本来想着先翻过 think in java 这本大山,但是读到一半就放弃了.过长的篇幅,让 ...
- 20个非常棒的jQuery倒计时脚本
使用jQuery倒计时插件可能是最简单最好的方式添加动态和交互式倒数计时器到您的网站上.我相信你已经注意到了,例如倒计时功能运行网站,显示倒计时,直到一个大事件.当网站正在维护,告诉用户什么时候回来, ...
- Windows下程序启动时出现0xc000007b错误的解决方案
一.背景介绍 不久前用Qt开发了一款小工具在公司使用,Debug运行时一切正常.可是当Release编译发布打包之后,运行时弹出这样的提示框: 略一思考,首先排除了DLL缺失的可能性.我知道Qt应用程 ...
- C#获取图片的后缀名
最近在学习过程中遇到一个问题,就是如何获取图片的格式,对于一张知道全路径的照片,如果其路径包含后缀名的话,要取得后缀名,只需要一行代码即可: var ext = System.IO.Path.GetE ...
- jsp原理
在eclipse里jsp编译后的java和class文件的位置 eclipse版本不一样,位置也不一样第一种:1.java类编译后产生的.class文件在D:\workspace\test\WEB-I ...
- 基于C#的MongoDB数据库开发应用(4)--Redis的安装及使用
在前面介绍了三篇关于MongoDB数据库的开发使用文章,严格来讲这个不能归类于MongoDB数据库开发,不过Redis又有着和MongoDB数据库非常密切的关系,它们两者很接近,Redis主要是内存中 ...
- 使用c#对windows进行关机、重启或注销
方法一:调用windows自带的shutdown.exe (缺点:会出现倒计时窗口) System.Diagnostics.Process.Start("shutdown.exe" ...
- 【转】asp.net(c#)使用HttpWebRequest附加携带请求参数以post方式模拟上传大文件(以图片为例)到Web服务器端
原文地址:http://docode.top/Article/Detail/10002 目录: 1.Http协议上传文件(以图片为例)请求报文体内容格式 2.完整版HttpWebRequest模拟上传 ...
- java for循环冒泡排序
int[]a =new int[]{7,19,66,21,88,40}; for(int i=1;i<=a.length-1;i++){ //比总长度减1趟就排好序了.因为每一趟出一个值. fo ...