0

0

MySQL 5.6利用GTIDs构建主从数据库

php中文网

php中文网

发布时间:2016-06-07 15:53:50

|

1364人浏览过

|

来源于php中文网

原创

(Global Transactions Identifier)是MySQL5.6.5新加入的一项新特性。当使用GTIDS时,无论是在Master上提交事物还是在Slave上应

【概念】什么是gtids

(Global Transactions Identifier)是MySQL5.6.5新加入的一项新特性。

【关于GTID】GTID由source_id和transaction_id两部门组成。

  • source_id来自于server_uuid,可以在auto.cnf文件中查看;
  • tranction_id是一个序列数字,从小到达自动生成;

  • [root@t-db01 mysql]# cat auto.cnf
    [auto]
    server-uuid=268e23d1-2216-11e5-abcc-000c296ecd05

    mysql> show global variables like 'gtid_executed';
    +---------------+-----------------------------------------------------+
    | Variable_name | Value                                                                  |
    +---------------+-----------------------------------------------------+
    | gtid_executed  | 268e23d1-2216-11e5-abcc-000c296ecd05:1-28    |
    +---------------+-----------------------------------------------------+

    【构建主从数据库】

    环境说明:

      主库信息 从库信息

    数据库版本 5.6.23 5.6.23

    IP地址 192.168.47.169 192.168.47.186

    同步数据库 JOHN_DB  

    同步用户 repl  

    1、主库参数的设置

    server_id = 1
    binlog-format=ROW  #建议使用ROW格式
    log-bin=mysql-bin      #打开binlog
    report-port=3306
    gtid-mode=on
    enforce-gtid-consistency=true
    log-slave-updates=true
    replicate_do_db=JOHN_DB

    2、从库参数的设置

    server_id = 2
    log-bin=mysql-bin
    report-port=3306
    gtid-mode=on
    enforce-gtid-consistency=true
    log-slave-updates=true
    replicate_do_db=JOHN_DB
    skip-slave-start    #启动的时候自动打开复制

    检查gtid是否启用:show global variables like ‘%gtid%’;

    MySQL 5.6利用GTIDs构建主从数据库

    3、在主库上面用户的创建

    grant replication slave on JOHN_DB.* to 'repl'@'192.168.47.186' identified by 'repl';

    4、进行从库数据的初始化

    操作的步骤跟5.5的步骤一样,这边就偷懒不再重复了;

    5、配置从库连接主库

    从库连接主库:
    change master to master_host='192.168.47.169', master_user='repl',master_password='repl',master_auto_position=1;

    启动从库:
    start slave;

    检查状态:
    show slave status\G;


    mysql> show slave status\G;
    *************************** 1. row ***************************
                  Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.47.169
                      Master_User: repl
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: mysql-bin.000009
              Read_Master_Log_Pos: 485
                  Relay_Log_File: t-db02-relay-bin.000012
                    Relay_Log_Pos: 695
            Relay_Master_Log_File: mysql-bin.000009
                Slave_IO_Running: Yes
                Slave_SQL_Running: Yes
                  Replicate_Do_DB: JOHN_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: 0
              Exec_Master_Log_Pos: 485
                  Relay_Log_Space: 1150
                  Until_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: 0
    Master_SSL_Verify_Server_Cert: No
                    Last_IO_Errno: 0
                    Last_IO_Error:
                  Last_SQL_Errno: 0
                  Last_SQL_Error:
      Replicate_Ignore_Server_Ids:
                Master_Server_Id: 31
                      Master_UUID: 268e23d1-2216-11e5-abcc-000c296ecd05
                Master_Info_File: /data/mysql/master.info
                        SQL_Delay: 0
              SQL_Remaining_Delay: NULL
          Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
              Master_Retry_Count: 86400
                      Master_Bind:
          Last_IO_Error_Timestamp:
        Last_SQL_Error_Timestamp:
                  Master_SSL_Crl:
              Master_SSL_Crlpath:
              Retrieved_Gtid_Set: 268e23d1-2216-11e5-abcc-000c296ecd05:1-29
                Executed_Gtid_Set: 268e23d1-2216-11e5-abcc-000c296ecd05:1-29
                    Auto_Position: 1
    1 row in set (0.02 sec)

    ERROR:
    No query specified

    自动找到binlog位置,并进行同步;
     

    经过以上操作便完成了mysql主从架构的搭建;

    齐博B2B电子商务系统
    齐博B2B电子商务系统

    齐博B2B系统是一款基于PHP程序和Mysql数据库为基础的开源B2B行业门户电子商务网站建站系统, 系统代码完整、开源,功能全面,架构优秀,提供良好的用户体验、及管理平台,是目前搭建B2B行业门户网站最好的程序之一。齐博B2B具有的功能特点包括:通行证整合功能通过通行证的整合,可以与流行的PHPWIND论坛或Discuz论坛以及Ucenter中心等进行通讯,从而为用户提供更多的交流场所,增加网站

    下载

    【常见问题的处理方法】

    1、场景的模拟

    步骤一:主库上面创建表john,并插入3行数据。(这个时候从库和主库的数据是一致的)

    mysql> select * from john;
    +------+
    | id  |
    +------+
    | 1    |
    | 2    |
    | 3    |
    +------+
    3 rows in set (0.19 sec)

    步骤二:从库关闭slave状态

    mysql> stop slave;

    步骤三:主库关闭写binlog

    mysql>  set sql_log_bin=off;  关闭
    Query OK, 0 rows affected (0.03 sec)

    步骤四:主库插入值4

    mysql> insert into john values(4);
    Query OK, 1 row affected (0.04 sec)

    步骤五:主库启动binlog

    mysql> set sql_log_bin=on;
    Query OK, 0 rows affected (0.00 sec)

    步骤六:主库插入值 5

    mysql> insert into john values(5);
    Query OK, 1 row affected (0.00 sec)

    经过以上步骤,主库和从库中john的值已经不一致了;

    主库如下:

    MySQL 5.6利用GTIDs构建主从数据库

    从库如下:

    MySQL 5.6利用GTIDs构建主从数据库

    步骤六:修改主库id为4的行,这个时候从库就会报错了

    MySQL 5.6利用GTIDs构建主从数据库


     

    Retrieved_Gtid_Set: a989adc2-2a8e-11e5-a308-000c296ecd05:1-30  主库的Gtid序号
    Executed_Gtid_Set: a989adc2-2a8e-11e5-a308-000c296ecd05:1-29  从库执行Gtid序号
     

    2、问题原因:由于id=4是没有写日志的,所以id=4并没有同步到从库,当主库删除id=4这条记录的时候,,从库找不到这条记录所以报错了;

    3、解决方法:GTIDs模式下的主从问题,操作如下:

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    C++ 设计模式与软件架构
    C++ 设计模式与软件架构

    本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

    7

    2026.01.30

    c++ 字符串格式化
    c++ 字符串格式化

    本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

    7

    2026.01.30

    java 字符串格式化
    java 字符串格式化

    本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

    1

    2026.01.30

    python 字符串格式化
    python 字符串格式化

    本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

    1

    2026.01.30

    java入门学习合集
    java入门学习合集

    本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

    20

    2026.01.29

    java配置环境变量教程合集
    java配置环境变量教程合集

    本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

    16

    2026.01.29

    java成品学习网站推荐大全
    java成品学习网站推荐大全

    本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

    18

    2026.01.29

    Java字符串处理使用教程合集
    Java字符串处理使用教程合集

    本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

    3

    2026.01.29

    Java空对象相关教程合集
    Java空对象相关教程合集

    本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

    6

    2026.01.29

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    PHP自制框架
    PHP自制框架

    共8课时 | 0.6万人学习

    mysql8主从复制原理底层详解
    mysql8主从复制原理底层详解

    共1课时 | 544人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号