mysql 5.6 gtid 主从_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_id

MySQL 5.6 中,每一个 GTID 代表一个数据库事务。在上面的定义中,source_id 表示执行事务的主库 uuid(server_uuid),transaction_id 是一个从 1 开始的自增计数,表示在这个主库上执行的第 n 个事务。MySQL 会保证事务与 GTID 之间的 1 : 1 映射。

二、环境准备

操作系统:CentOS6.5 64位

数据库版本:MySQL5.6.23

568a43e731a9fee6c68dd0c100099470.png

拓扑如下:

edd0d5b1a7663118aee074894d55accf.png

三、安装主数据库(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 mysql4 [root@masterdb ~]# chown -R root.mysql mysql5 [root@masterdb ~]# cd mysql6 [root@masterdb ~]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld7 [root@masterdb ~]# cp support-files/my-default.cnf /etc/my.cnf8 [root@masterdb ~]# chmod +x /etc/rc.d/init.d/mysqld9 [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/man

4、输出mysql的头文件至系统头文件路径/usr/include:

这可以通过简单的创建链接实现:

1 [root@masterdb ~]#ln -sv /usr/local/mysql/include /usr/include/mysql

5、输出mysql的库文件给系统库查找路径:

1 [root@masterdb ~]#echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

而后让系统重新载入系统库:

1 [root@masterdb ~]# ldconfig

6、修改PATH环境变量,让系统可以直接使用mysql的相关命令:

1 [root@masterdb ~]# vim /etc/profile.d/mysql.sh

2 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.sock4 default-character-set =utf85 [mysql]6 no-auto-rehash7 default-character-set =utf88

9 [mysqld]10 server-id = 1

11 port = 3306

12 user =mysql13 basedir = /usr/local/mysql14 datadir = /data/mysqldata15 socket = /tmp/mysql.sock16 default-storage-engine =INNODB17 character-set-server =utf818 connect_timeout = 60

19 interactive_timeout = 28800

20 wait_timeout = 28800

21 back_log = 500

22 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 = 5

31 log-slave-updates=true

32 gtid-mode=on33 enforce-gtid-consistency=true

34 master-info-repository=TABLE35 relay-log-info-repository=TABLE36 sync-master-info=1

37 slave-parallel-workers=4

38 #rpl_semi_sync_master_enabled = 1

39

40 slow_query_log = 1

41 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 1

43

44 log_error = /data/mysqlLog/logs/error.log45 max_connections = 3000

46 max_connect_errors = 32767

47 log_bin_trust_function_creators = 1

48 transaction_isolation = READ-COMMITTED

从数据库上:

1 [client]2 port = 3306

3 socket = /tmp/mysql.sock4 default-character-set =utf85

6 [mysql]7 no-auto-rehash8 default-character-set =utf89

10 [mysqld]11 server-id = 205

12 port = 3306

13 user =mysql14 basedir = /usr/local/mysql15 datadir = /data/mysqldata16 socket = /tmp/mysql.sock17 default-storage-engine =INNODB18 character-set-server =utf819 connect_timeout = 60

20 wait_timeout = 18000

21 back_log = 500

22 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 = 5

30 log-slave-updates=true

31 gtid-mode=on32 enforce-gtid-consistency=true

33 master-info-repository=TABLE34 relay-log-info-repository=TABLE35 sync-master-info=1

36 slave-parallel-workers=4

37 #rpl_semi_sync_slave_enabled = 1

38 skip-slave-start39

40 slow_query_log = 1

41 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 2

43

44 log-error = /data/mysqlLog/logs/error.log45 max_connections = 3000

46 max_connect_errors = 10000

47 log_bin_trust_function_creators = 1

48 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 status\G;*************************** 1. row ***************************Slave_IO_State: Waitingformaster to send event

Master_Host: masterdb.56xyl.com

Master_User: repluser

Master_Port:3306Connect_Retry:60Master_Log_File: mysql-bin.000002Read_Master_Log_Pos:191Relay_Log_File: slavedb-relay-bin.000003Relay_Log_Pos:401Relay_Master_Log_File: mysql-bin.000002Slave_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:0Last_Error:

Skip_Counter:0Exec_Master_Log_Pos:191Relay_Log_Space:1899Until_Condition: None

Until_Log_File:

Until_Log_Pos:0Master_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: No

Last_IO_Errno:0Last_IO_Error:

Last_SQL_Errno:0Last_SQL_Error:

Replicate_Ignore_Server_Ids:

Master_Server_Id:1Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5

Master_Info_File: mysql.slave_master_info

SQL_Delay:0SQL_Remaining_Delay: NULL

Slave_SQL_Running_State: Slave has read all relay log; waitingfor 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:1

1 row in set (0.00sec)

ERROR:

No query specified

mysql>

九、测试

在主库上创建数据库:

1 mysql>create database log_statics;2 Query OK, 1 row affected (0.11sec)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.01sec)11

12 mysql>

可以看到log_statics数据库已经存在于从数据库上。

--------------------------------------分割线 --------------------------------------

--------------------------------------分割线 --------------------------------------

0b1331709591d260c1c78e86d0c51c18.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/267103.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring Boot之HelloWorld

视频网址&#xff1a;http://www.iqiyi.com/w_19ruksbpf1.html <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http://maven.a…

防止黑客入侵的五大技巧

2019独角兽企业重金招聘Python工程师标准>>> 防止黑客入的方法有很多&#xff0c;但是世界上没有绝对安全的系统。我们只可以尽量避免被入侵&#xff0c;最大的程度上减少伤亡。那么&#xff0c;接下来天下数据将为您详细介绍防止黑客入侵的五大技巧。(本文为天下数…

mysql js 命令行登录_mysqlsh 命令行模式与密码保存-爱可生

原标题&#xff1a;mysqlsh 命令行模式与密码保存-爱可生命令行模式mysql shell 如何实现类似 mysql -e "show processlist;" 的效果&#xff1f;即执行完就退出登录&#xff0c;不需要交互&#xff0c;我们经常在脚本中这样使用。那么同样的&#xff0c;在维护 Inno…

AngularJS学习笔记(1)——MVC模式的清单列表效果

MVC模式的清单列表效果 使用WebStorm新建todo.html并链入bootstrap.css、bootstrap-theme.css、angular.js。要链入的相关css和js文件预先准备好&#xff0c;文件目录如下&#xff1a; 使用MVC模式前的代码&#xff1a; <!DOCTYPE html> <html ng-app> <head&g…

C#多线程学习(六) 互斥对象

C#多线程学习(六) 互斥对象 原文链接&#xff1a;http://kb.cnblogs.com/page/42533/ 本系列文章导航 C#多线程学习(一) 多线程的相关概念 C#多线程学习(二) 如何操纵一个线程 C#多线程学习(三) 生产者和消费者 C#多线程学习(四) 多线程的自动管理(线程池) C#多线程学习(五) 多…

什么是mysql事物定义_Mysql事务原理

1. 什么是数据库事务1.1 事务的应用场景电商平台中例如常见的下单流程&#xff0c;会同时操作订单表&#xff0c;库存表等&#xff0c;有时候这些操作要在一个事务里面完成。还有金融系统业务的银行转账&#xff0c;需要保证一个账户增加另一个账户减少&#xff0c;这两个动作 …

学习jvm,关于MAT an internal error occurred during:Parsing heap dump from问题

写了一个死循环不断的创建对象&#xff0c;模拟内存溢出 1 package com.zuo.test1;2 3 import java.util.ArrayList;4 import java.util.List;5 6 public class Main {7 8 public static void main(String[] args) {9 List<Demo> demosnew ArrayList<…

mysql报错5_mysql5.5 启动报错:ERROR!_MySQL

bitsCN.com在FreeBSD中启动mysql时报错&#xff0c;ERROR! The server quit without updating PID file&#xff0c;通常这是可以查看数据库目录下的.err日志&#xff0c;里面会记录一些具体的错误信息&#xff0c;对排错相当有用&#xff0c;内容如下&#xff1a;110805 17:30…

MySQL安装总结

安装MySQL&#xff1a;&#xff08;以安装5.1版本为例&#xff09; 1. 双击你下载的安装程序&#xff0c;然后会进入一个‘Welecom to the Setup Wizard for MySQL Server 5.1’的图形界面&#xff01;在这里不用做任何操作&#xff0c;点击next&#xff0c;进入下一步&a…

java swing事件_第四节 Java Swing事件处理

第四节&#xff1a;事件处理一个图形界面完的成只是程序开发中起步的工作&#xff0c;因为要想让每一个组件都发挥其作用&#xff0c;就必须对所有的组件进行事件处理。那么什么是事件处理&#xff0c;所谓事件就表示一个对象发生状态变化。例如&#xff0c;每当按下一个按钮时…

jedate-开始使用一款好用的时间插件

jeDate日期控件 -&#xff08;原生JS版&#xff09;jeDate V6.5.0 是一款原生JS开发的 不依赖任何第三方库 大众化的日期控件&#xff0c;包含 多语言、设定年月&#xff08;YYYY-MM&#xff09;、日期范围限制、开始日期设定、自定义日期格式、根据不同的日期格式&#xff0c;…

zabbix的安装(一)监控os资源:内存,cpu,io,负载,带宽

一、Linux下开源监控系统简单介绍1&#xff09;cacti&#xff1a;存储数据能力强&#xff0c;报警性能差2&#xff09;nagios&#xff1a;报警性能差&#xff0c;存储数据仅有简单的一段可以判断是否在合理范围内的数据长度&#xff0c;储存在内存中。比如&#xff0c;连续采样…

linux下rpm方式安装mysql(2012-5-12)

由于感觉前几篇博客中关于linux下rpm方式安装mysql的方法问题太多&#xff0c;今天抽时间重新实践和整理了一下&#xff0c;现在拿出来和大家分享&#xff0c;希望对家有用。 系统环境&#xff1a;Rat had enterprise linux server 6.1MySQL-5.5.22-1.linux2.6.i386VMware Work…

list java语法_java基础语法 List

List的用法List包括List接口以及List接口的所有实现类。因为List接口实现了Collection接口&#xff0c;所以List接口拥有Collection接口提供的所有常用方法&#xff0c;又因为List是列表类型&#xff0c;所以List接口还提供了一些适合于自身的常用方法&#xff0c;如表1所示。表…

基础练习

口述题1.分别解释"","",""的含义。 是赋值语句 把一个值赋值给另一个值 是判断语句 判断两个值是否相等 是赋值语句 a1 等价于 aa1 2.两个变量的关系&#xff1f;n1123456n2n1 把123456赋值给变量n1,把n2赋值给n1,n1,n2共同指向123456这个地址 …

求大神解决下这个题目!做好请发到308960728@qq.com

RIP动态路由配置RIP是使用最广泛的距离向量协议&#xff0c;通过本次配置来理解RIP协议的传播、分析、挑选路由&#xff0c;来实现路由发现、路由选择、路由切换等功能&#xff0c;掌握RIP动态路由信息协议的配置方法。1.RIP配置环境与网络拓扑结构图实验设备&#xff1a;3台CI…

elastic search java_在 Java 应用程序中使用 Elasticsearch

如果您使用过 Apache Lucene 或 Apache Solr&#xff0c;就会知道它们的使用体验非常有趣。尤其在您需要扩展基于 Lucene 或 Solr 的解决方案时&#xff0c;您就会了解 Elasticsearch 项目背后的动机。Elasticsearch(构建于 Lucene 之上)在一个容易管理的包中提供了高性能的全文…

PostgreSQL增强版命令行客户端(pgcli)

效果&#xff1a; 安装&#xff1a; https://www.pgcli.com/install 官网&#xff1a; https://www.pgcli.com/ 转载于:https://www.cnblogs.com/EasonJim/p/9042418.html

网络设备的注册与初始化

2019独角兽企业重金招聘Python工程师标准>>> NIC可用之前&#xff0c;其相关联的net_device数据结构必须先初始化&#xff0c;添加到内核网络设备数据库、配置并开启。不要把注册/除名以及开启/关闭混淆是十分重要的&#xff0c;这是两种不同的概念&#xff1a; 如果…

[转]敏捷开发中编写高质量Java代码

本文转自&#xff1a;http://dev.yesky.com/103/11164603.shtml 敏捷开发的理念已经流行了很长的时间&#xff0c;在敏捷开发中的开发迭代阶段中&#xff0c;我们可以通过五个步骤&#xff0c;来有效的提高整个项目的代码质量。 Java项目开发过程中&#xff0c;由于开发人员的…