mysql导出入关于gtid问题

今天在to5测试环境导出一个lms的数据库,然后导入到预发布环境中做压测
查看to5的数据库很小,于是准备使用mysqldump命令做导出。


[root@db ~]# mysqldump -uroot -p'' -S /tmp/mysql_che.sock lms > /tmp/lms.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. 


命令执行好之后,导出成功了,但是有一个waring。
百度了一下报错的原因,gtid-purged
***********************************************
关于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,而不用原来的。
************************************************


后添加参数:--set-gtid-purged=OFF
[root@db ~]# mysqldump -uroot -p'' -S /tmp/mysql_che.sock --set-gtid-purged=OFF lms > /tmp/lms.sql


导出成功。


预发布环境:
创建数据库:
mysql>create database lms


[root@db ~]#mysql-uroot -p'' -S /tmp/mysql_che.sock  lms < /tmp/lms.sql


导入成功。


-----------------------------------------------
备份的时候本来发现是个warning并且也成功产生了sql文件,就没在意。但是发现导入到预发布环境的时候报错了。于是才重视起来。




MySQL GTID 基本概念
转载 2016-08-28 18:23:27
标签:杂谈
背景
1. 什么是GTID?


GTID(Global Transaction ID)是对于一个已提交事务的编号,并且是一个全局唯一的编号。它的官方定义如下:


​GTID = source_id :transaction_id


​每一个 GTID 代表一个数据库事务。在上面的定义中,source_id 表示执行事务的主库 uuid(server_uuid),transaction_id 是一个从 1 开始的自增计数,表示在这个主库上执行的第 n 个事务。MySQL 只要保证每台数据库的 server_uuid 全局唯一,以及每台数据库生成的 transaction_id 自身唯一,就能保证 GTID 的全局唯一性。

你可能感兴趣的:(mysql导出入关于gtid问题)