首页 / 数据库 / MySQL / MySQL5.6基于GTID的主从复制
一、GTID简介MySQL 5.6 的新特性之一,是加入了全局事务 ID (GTID) 来强化数据库的主备一致性,故障恢复,以及容错能力。什么是GTID?官方文档:http://dev.mysql.com/doc/refman/5.6/en/replication-gtids.html在这篇文档里,我们可以知道全局事务 ID 的官方定义是:GTID = source_id:transaction_idMySQL 5.6 中,每一个 GTID 代表一个数据库事务。在上面的定义中,source_id 表示执行事务的主库 uuid(server_uuid),transaction_id 是一个从 1 开始的自增计数,表示在这个主库上执行的第 n 个事务。MySQL 会保证事务与 GTID 之间的 1 : 1 映射。二、环境准备操作系统:CentOS6.5 64位数据库版本:MySQL5.6.23 拓扑如下:三、安装主数据库(masterdb.example.com)1、准备数据存放目录、创建用户 1 1 [root@masterdb ~]#mkdir /data/mysqldata -p #创建数据存放目录2 2 [root@masterdb ~]#mkdir /data/mysqlLog/logs -p#创建日志存放目录3 3 [root@masterdb ~]#groupadd -r mysql4 4 [root@masterdb ~]#useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql5 5 [root@masterdb ~]#chown -R mysql:mysql /data/mysqldata6 6 [root@masterdb ~]#chown -R mysql:mysql /data/mysqlLog/logs 2、安装并初始化mysql5.6.23 1 [root@masterdb ~]# tar xf mysql-advanced-5.6.23-linux-glibc2.5-x86_64.tar.gz -C /usr/local/ 2 [root@masterdb ~]# cd /usr/local/ 3 [root@masterdb ~]# ln -sv mysql-advanced-5.6.23-linux-glibc2.5-x86_64 mysql 4 [root@masterdb ~]# chown -R root.mysql mysql 5 [root@masterdb ~]# cd mysql 6 [root@masterdb ~]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld 7 [root@masterdb ~]# cp support-files/my-default.cnf /etc/my.cnf 8 [root@masterdb ~]# chmod +x /etc/rc.d/init.d/mysqld 9 [root@masterdb ~]# chkconfig --add mysqld10 [root@masterdb ~]# chkconfig mysqld on11 [root@masterdb ~]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldata/ 3、输出mysql的man手册至man命令的查找路径:编辑/etc/man.config,添加如下行即可:
MANPATH /usr/local/mysql/man4、输出mysql的头文件至系统头文件路径/usr/include:这可以通过简单的创建链接实现:1 [root@masterdb ~]#ln -sv /usr/local/mysql/include/usr/include/mysql5、输出mysql的库文件给系统库查找路径:1 [root@masterdb ~]#echo "/usr/local/mysql/lib" > /etc/ld.so.conf.d/mysql.conf而后让系统重新载入系统库:1 [root@masterdb ~]# ldconfig6、修改PATH环境变量,让系统可以直接使用mysql的相关命令:1 [root@masterdb ~]# vim /etc/profile.d/mysql.sh2 export PATH=$PATH:/usr/local/mysql/bin3 [root@masterdb ~]#source /etc/profile.d/mysql.sh从数据库安装同上,具体过程略过。四、分别为主从数据库提供配置文件/etc/my.cnf要在MySQL 5.6中使用复制功能,其服务配置段[mysqld]中于少应该定义如下选项:
binlog-format:二进制日志的格式,有row、statement和mixed几种类型;
需要注意的是:当设置隔离级别为READ-COMMITED必须设置二进制日志格式为ROW,现在MySQL官方认为STATEMENT这个已经不再适合继续使用;但mixed类型在默认的事务隔离级别下,可能会导致主从数据不一致;
log-slave-updates、gtid-mode、enforce-gtid-consistency、report-port和report-host:用于启动GTID及满足附属的其它需求;
master-info-repository和relay-log-info-repository:启用此两项,可用于实现在崩溃时保证二进制及从服务器安全的功能;
sync-master-info:启用之可确保无信息丢失;
slave-paralles-workers:设定从服务器的SQL线程数;0表示关闭多线程复制功能;
binlog-checksum、master-verify-checksum和slave-sql-verify-checksum:启用复制有关的所有校验功能;
binlog-rows-query-log-events:启用之可用于在二进制日志记录事件相关的信息,可降低故障排除的复杂度;
log-bin:启用二进制日志,这是保证复制功能的基本前提;
server-id:同一个复制拓扑中的所有服务器的id号必须惟一;主数据库上: 1 [client] 2 port = 3306 3 socket = /tmp/mysql.sock 4 default-character-set = utf8 5 [mysql] 6 no-auto-rehash 7 default-character-set = utf8 89 [mysqld]10 server-id = 111 port = 330612 user = mysql13 basedir = /usr/local/mysql14 datadir = /data/mysqldata15 socket = /tmp/mysql.sock16 default-storage-engine = INNODB17 character-set-server = utf818 connect_timeout = 6019 interactive_timeout = 2880020 wait_timeout = 2880021 back_log = 50022 event_scheduler = ON23 skip_name_resolve = ON;24 25 ###########binlog##########26 log-bin = /data/mysqlLog/logs/mysql-bin27 binlog_format = row28 max_binlog_size = 128M29 binlog_cache_size = 2M30 expire-logs-days = 531 log-slave-updates=true32 gtid-mode=on33 enforce-gtid-consistency=true34 master-info-repository=TABLE35 relay-log-info-repository=TABLE36 sync-master-info=137 slave-parallel-workers=438 #rpl_semi_sync_master_enabled = 139 40 slow_query_log = 141 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 143 44 log_error = /data/mysqlLog/logs/error.log45 max_connections = 300046 max_connect_errors = 3276747 log_bin_trust_function_creators = 148 transaction_isolation = READ-COMMITTED从数据库上: 1 [client] 2 port = 3306 3 socket = /tmp/mysql.sock 4 default-character-set = utf8 56 [mysql] 7 no-auto-rehash 8 default-character-set = utf8 9 10 [mysqld]11 server-id = 20512 port = 330613 user = mysql14 basedir = /usr/local/mysql15 datadir = /data/mysqldata16 socket = /tmp/mysql.sock17 default-storage-engine = INNODB18 character-set-server = utf819 connect_timeout = 6020 wait_timeout = 1800021 back_log = 50022 event_scheduler = ON23 24 ###########binlog##########25 log-bin = /data/mysqlLog/logs/mysql-bin26 binlog_format = row27 max_binlog_size = 128M28 binlog_cache_size = 2M29 expire-logs-days = 530 log-slave-updates=true31 gtid-mode=on 32 enforce-gtid-consistency=true33 master-info-repository=TABLE34 relay-log-info-repository=TABLE35 sync-master-info=136 slave-parallel-workers=437 #rpl_semi_sync_slave_enabled = 138 skip-slave-start39 40 slow_query_log = 141 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 243 44 log-error = /data/mysqlLog/logs/error.log45 max_connections = 300046 max_connect_errors = 1000047 log_bin_trust_function_creators = 148 transaction_isolation = READ-COMMITTED五、分别在主从数据库上启动mysqld服务1 [root@masterdb ~]# service mysqld start2 Starting MySQL...... [OK]3 [root@masterdb ~]# 1 [root@slavedb ~]# service mysqld start2 Starting MySQL...... [OK]3 [root@slavedb ~]# 六、在主数据库上创建复制用户1 mysql> GRANT REPLICATION SLAVE ON *.* TO repluser@172.16.88.205 IDENTIFIED BY "replpassword";说明:172.16.88.205是从节点服务器;如果想一次性授权更多的节点,可以自行根据需要修改;七、启动从数据库上的复制线程mysql> CHANGE MASTER TO MASTER_HOST="masterdb.example.com", MASTER_USER="repluser", MASTER_PASSWORD="replpassword", MASTER_AUTO_POSITION=1;mysql>start slave;八、在从数据库上查看复制状态:mysql> show slave statusG;*************************** 1. row *************************** Slave_IO_State: Waiting for master to send eventMaster_Host: masterdb.56xyl.comMaster_User: repluserMaster_Port: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000002Read_Master_Log_Pos: 191 Relay_Log_File: slavedb-relay-bin.000003Relay_Log_Pos: 401Relay_Master_Log_File: mysql-bin.000002 Slave_IO_Running: Yes #IO线程已正常运行Slave_SQL_Running: Yes #SQL线程已正常运行Replicate_Do_DB: Replicate_Ignore_DB:Replicate_Do_Table:Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table:Last_Errno: 0 Last_Error:Skip_Counter: 0Exec_Master_Log_Pos: 191Relay_Log_Space: 1899Until_Condition: None Until_Log_File: Until_Log_Pos: 0 Master_SSL_Allowed: No Master_SSL_CA_File:Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher:Master_SSL_Key: Seconds_Behind_Master: 0Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error:Last_SQL_Errno: 0 Last_SQL_Error: Replicate_Ignore_Server_Ids:Master_Server_Id: 1Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5 Master_Info_File: mysql.slave_master_infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it Master_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp:Last_SQL_Error_Timestamp:Master_SSL_Crl:Master_SSL_Crlpath:Retrieved_Gtid_Set: 971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6Executed_Gtid_Set: 89e78301-c3f4-11e5-8b51-00505624d26a:1-3,971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6Auto_Position: 11 row in set (0.00 sec)ERROR: No query specifiedmysql> 九、测试在主库上创建数据库:1 mysql> create database log_statics;2 Query OK, 1 row affected (0.11 sec)3 4 mysql> use log_statics;5 Database changed到从数据库上查看log_statics是否已经复制过去 1 mysql> show databases; 2 +--------------------+ 3 | Database | 4 +--------------------+ 5 | information_schema | 6 | log_statics| 7 | mysql| 8 | performance_schema | 9 +--------------------+10 4 rows in set (0.01 sec)11 12 mysql>可以看到log_statics数据库已经存在于从数据库上。 --------------------------------------分割线 -------------------------------------- Ubuntu下Nginx做负载实现高性能WEB服务器5---MySQL主主同步 http://www.linuxidc.com/Linux/2012-06/61687p5.htm 生产环境MySQL主主同步主键冲突处理 http://www.linuxidc.com/Linux/2013-07/86890.htm MySQL主从失败 错误Got fatal error 1236 http://www.linuxidc.com/Linux/2012-02/54729.htm MySQL主从复制,单台服务器上实施 http://www.linuxidc.com/Linux/2013-03/81913.htm 搭建MySQL代理服务器实现读写分离+主从同步 http://www.linuxidc.com/Linux/2014-05/102265.htm MySQL 5.5 主从双向同步 http://www.linuxidc.com/Linux/2012-12/75973.htm MySQL 5.5主从同步排错 http://www.linuxidc.com/Linux/2014-08/105416.htm MySQL主从复制异步半同步实例 http://www.linuxidc.com/Linux/2014-10/107608.htm --------------------------------------分割线 -------------------------------------- 本文永久更新链接地址