使用mysqldump备份数据库

mysqldump --opt ekt -uroot -ppassword -R -B --set-gtid-purged=OFF > ekt.sql

参数说明:

--opt

     如果加上--opt参数则生成的dump文件中稍有不同:

     . 建表语句包含drop table if exists tableName

     . insert之前包含一个锁表语句lock tables tableName write,insert之后包含unlock tables

 

-R (--routines:导出存储过程以及自定义函数)


-B (--databases:导出数据库列表,单个库时可省略)

 

--set-gtid-purged=OFF

导出时提示warning,A partial dump from a server that has GTIDs

[root@localhost data]# mysqldump -uroot --master-data=2 -p  --single-transaction --databases test >3.sql
Enter password: 
Warning: A partial dump from a server that has GTIDs will by default include the GTIDs of all transactions, even those that changed suppressed parts of the database. If you don't want to restore GTIDs, pass --set-gtid-purged=OFF. To make a complete dump, pass --all-databases --triggers --routines --events. 

 

关于GTID是5.6以后,加入了全局事务 ID (GTID) 来强化数据库的主备一致性,故障恢复,以及容错能力。
官方给的:A global transaction identifier (GTID) is a unique identifier created and associated with each transaction committed on the server of origin (master).
所以可能是因为在一个数据库里面唯一,但是当导入其他的库就有可能重复。所有会有一个提醒。

可以通过添加--set-gtid-purged=off  或者–gtid-mode=OFF这两个参数设置。
个人认为是在导入库中重新生产GTID,而不用原来的。

 

恢复数据库
source /var/www/html/backup/ekt_new.sql

posted on 2017-05-08 10:26  宇宙神奇  阅读(338)  评论(0编辑  收藏  举报