返回顶部
首页 > 资讯 > 数据库 >5:使用GTID进行复制
  • 216
分享到

5:使用GTID进行复制

2024-04-02 19:04:59 216人浏览 泡泡鱼
摘要

服务器 192.168.1.1(master) 192.168.1.2(slave) 同步服务器,只有当已经在复制但不使用gtid的服务器时才需要此步骤,,对于新服务器,请继续执行步骤5。将每个服务器上

  1. 服务器 192.168.1.1(master) 192.168.1.2(slave)
  2. 同步服务器,只有当已经在复制但不使用gtid的服务器时才需要此步骤,,对于新服务器,请继续执行步骤5。将每个服务器上的read_only系统变量设置为ON,使服务器成为只读的,方法是发出以下命令:
    • 分别在master和slave上
    • Mysql> SET @@global.read_only = ON;
    • Query OK, 0 rows affected (0.00 sec)
  3. 等待所有正在进行的事务提交或回滚。然后,让slave赶上master。在继续之前,确保slave已经处理了所有更新,这一点非常重要
  4. 将master和slave上面的mysql服务都停止
    • [root@iz2ze3bc56k6c4f3rsiahvz ~]# service mysqld stop
    • Redirecting to /bin/systemctl stop mysqld.service
    • #查看是否停止掉了
    • [root@iz2ze3bc56k6c4f3rsiahvz ~]# ps -ef | grep mysql
    • root 31143 30584 0 23:09 pts/0 00:00:00 grep --color=auto mysql
    • #确实停掉了
  5. 启用两台服务器并开启 GTIDs。要启用基于GTID的复制,必须在启用GTID模式的情况下启动每个服务器,方法是将gtid_mode变量设置为ON,并启用enforce_gtid_consistency变量以确保仅记录对基于GTID的复制安全的语句。此外,在配置slave设置之前,您应该使用-skip-slave-start 选项启动slaves。为什么需要指定--skip-slave-start,因为指定了--skip-slave-start的话,那么mysql启动的时候复制就不会启动。由于在MySQL 5.7.5中添加了mysql.gtid_executed表,因此为了使用GTIDs启用二进制日志记录不是必须的。这意味着您可以使用GTIDs但没有二进制日志记录的slave服务器。Masters必须始终启用二进制日志记录,以便能够复制。
    • 基于上面的讲述,我们需要针对master和slave进行不同的配置,下面我就贴上master和slave的配置图
    • master配置
      • 5:使用GTID进行复制
      • 参数解释
        • log-bin 表示开启二进制日志
        • server_id 这是唯一的,用来区分服务器,在复制拓扑结构中,不能出现相同的server_id
        • gtid_mode 表示开启GTID
        • enforce_gtid_consistency 确保仅记录对基于GTID的复制安全的语句
    • slave配置
      • 5:使用GTID进行复制
      • 参数解释(相同参数的解释请参考上面)
        • skip-slave-start 指定了--skip-slave-start的话,那么mysql启动的时候复制就不会启动
    • 然后启动master和slave的mysql,这时候可以将master的只读模式给禁用了
  6. 配置slave以使用基于GTID的自动定位。告诉slave使用具有基于GTID的事务的master作为复制数据源,并使用基于GTID的自动定位而不是基于文件的定位。在slave上发出CHANGE MASTER TO语句,包括语句中的MASTER_AUTO_POSITioN选项,告诉slave对应master的事务是由GTID识别的。MASTER_LOG_FILE选项和MASTER_LOG_POS选项都不能与MASTER_AUTO_POSITION设置为1一起使用,尝试这样做会导致CHANGE MASTER TO语句失败并显示错误。
    • 在master上
      • #创建复制账号
      • mysql> CREATE USER 'wangwu'@'%' IDENTIFIED BY 'Wangwu@123456';
      • Query OK, 0 rows affected (0.00 sec)
      • mysql> GRANT REPLICATION SLAVE ON . TO 'wangwu'@'%';
      • Query OK, 0 rows affected (0.01 sec)
      • #创建后一定要远程登录一下账号,验证一下是否能登录
    • 在slave上
      • 发出CHANGE MASTER TO
      • mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.1' ,MASTER_USER = 'wangwu',MASTER_PASSWord = 'Wangwu@123456', MASTER_AUTO_POSITION = 1;
      • Query OK, 0 rows affected, 2 warnings (0.01 sec)
      • 参数讲解
        • MASTER_HOST master的ip地址
        • MASTER_USER master的复制用户名
        • MASTER_PASSWORD master的复制用户的密码
        • MASTER_AUTO_POSITION 当将MASTER_AUTO_POSITION = 1与CHANGE MASTER TO一起使用时,slave尝试使用基于gtid的复制协议连接到master。
  7. 进行一个新的备份
    • 由于您已启用GTID,因此在启用GTIDs之前创建的现有备份现在无法在这些服务器上使用。。此时进行一个新的备份,这样您就不会没有一个可用的备份。
  8. 在slave上
    • 启动复制
    • mysql> start slave;
    • Query OK, 0 rows affected (0.00 sec)
    • #查看是否连接上了master
    • mysql> show slave status\G
    • 5:使用GTID进行复制
    • 看到了两个YES,那就说明没问题了
    • 禁用只读模式
    • 仅当您在步骤2中将服务器配置为只读时,才需要执行以下步骤。要允许服务器再次开始接受更新,请发出以下语句:
    • mysql> SET @@global.read_only = OFF;
    • Query OK, 0 rows affected (0.00 sec)
  9. 在master上面添加一些数据,然后在slave中是否能看到,如果能看到就说明没问题,如果看不到,就及时查看slave的错误日志

参考资料:https://dev.mysql.com/doc/refman/5.7/en/replication-gtids-howto.html

PREV:4:GTID简单介绍 Https://blog.51cto.com/itzhoujun/2352688
NEXT: 6:多源复制的实现 https://blog.51cto.com/itzhoujun/2353940

您可能感兴趣的文档:

--结束END--

本文标题: 5:使用GTID进行复制

本文链接: https://lsjlt.com/news/38011.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 5:使用GTID进行复制
    服务器 192.168.1.1(master) 192.168.1.2(slave) 同步服务器,只有当已经在复制但不使用gtid的服务器时才需要此步骤,,对于新服务器,请继续执行步骤5。将每个服务器上...
    99+
    2024-04-02
  • 如何进行MySQL主从GTID复制修复
    如何进行MySQL主从GTID复制修复,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。GTID是5.6新增特性,减少DBA运维的工作。在以前一主...
    99+
    2024-04-02
  • MySQL5.7中GTID复制的改进
    1、支持创建临时表 MySQL5.7版本可以支持create temporary table、drop temporary table命令。 2、开启GTID复制模式,不用开启log_slave_upda...
    99+
    2024-04-02
  • MySQL复制之GTID复制的具体使用
    目录GTID是什么GTID改进有哪些GTID的工作原理一主一从GTID复制的搭建master的配置slave的配置遇到的问题从MySQL 5.6.5开始新增了一种基于GTID的复制方...
    99+
    2024-04-02
  • MySQL之GTID复制怎么使用
    本篇内容主要讲解“MySQL之GTID复制怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL之GTID复制怎么使用”吧!从MySQL 5.6.5开始新增了一种基于GTID的复制方式...
    99+
    2023-06-30
  • MySQL的GTID复制怎么应用
    这篇文章主要介绍“MySQL的GTID复制怎么应用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL的GTID复制怎么应用”文章能帮助大家解决问题。从MySQ...
    99+
    2024-04-02
  • 如何使用MySQL进行主从复制
    1:MySQL主从复制介绍 (1)MySQL数据库默认是支持主从复制的,不需要借助于其他的技术,我们只需要在数据库中简单的配置即可。 (2)MySQL主从复制是一个异步的复制过程,底层是基于Mysql数据库自带的 二进制日志 功能。就是一台...
    99+
    2023-10-24
    mysql 数据库 服务器
  • mysql5.6新特性之GTID(可以做并行复制)
     GTID即全局事务ID(global transaction identifier),GTID实际上是由UUID+TID组成的。其中UUID是一个MySQL实例的唯一标识。TID代表了该实例上已...
    99+
    2024-04-02
  • 【Mysql】Mysql GTID复制进程出现异常,出现断点
    昨天处理了一个MySQL 5.6版本下开启GTID模式复制异常案例,MASTER上的任何操作都无法在SLAVE上应用,SLAVE的RELAY LOG里有记录,但SLAVE的BINLOG却找不到蛛丝...
    99+
    2024-04-02
  • MySQL 5.7如何使用GTID方式搭建复制环境
    这篇文章主要为大家展示了“MySQL 5.7如何使用GTID方式搭建复制环境”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL 5.7如何使用GTID方式...
    99+
    2024-04-02
  • 使用Office剪贴板进行复制和粘贴
    使用Office剪贴板进行复制和粘贴可以帮助提高您在Office程序中的工作效率。以下是使用剪贴板进行复制和粘贴的步骤:1. 打开要...
    99+
    2023-09-13
    Office
  • 如何使用RMAN对CDB中的PDB进行复制
    本篇内容主要讲解“如何使用RMAN对CDB中的PDB进行复制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用RMAN对CDB中的PDB进行复制”吧! 1....
    99+
    2024-04-02
  • 详解使用Docker进行Redis主从复制实践
    目录一、背景 二、操作步骤三、安装Docker 四、主服务配置 五、从服务配置 六、结果验证 6.1 初步验证 6.2 同步检查 一、背景 最近在做零信任安全网关,需要使用Redi...
    99+
    2024-04-02
  • 如何使用Node.js+COW技术进行进程创建和文件复制
    如何使用Node.js+COW技术进行进程创建和文件复制,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。COW 不是奶牛,是 Copy-On-W...
    99+
    2024-04-02
  • HTML 5缓存机制中如何进行Cache Manifest配置
    这篇文章给大家介绍HTML 5缓存机制中如何进行Cache Manifest配置,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Cache Manifest是HTML 5的一种缓存机制,...
    99+
    2024-04-02
  • 如何在Mysql数据表中使用蠕虫进行复制
    本文章向大家介绍如何在Mysql数据表中使用蠕虫进行复制,主要包括如何在Mysql数据表中使用蠕虫进行复制的使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。首先...
    99+
    2024-04-02
  • 如何进行MySQL并行复制测试
    今天就跟大家聊聊有关如何进行MySQL并行复制测试,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。    对于主从延迟,其实一...
    99+
    2024-04-02
  • ORACLE 12C使用RMAN进行表恢复
         在12C以前的版本中rman可以进行db,tablespace,datafile,block级别和TSPITR的恢复,12C引入了table级别的恢复在...
    99+
    2024-04-02
  • 【MySQL8入门到精通】高可用-1主2从GTID复制
    📢📢📢📣📣📣 哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10年DBA工作经验 一位上进心十足的【大数据领域博主】!😜😜😜 中国DBA联盟(ACDU)成员,目前从事DBA及程序编程...
    99+
    2023-09-13
    mysql 数据库
  • Android使用MediaRecorder类进行录制视频
    编程网提醒大家使用MediaRecorder录音录像的设置代码步骤一定要按照API指定的顺序来设置,否则报错 步骤为: 1、设置视频源,音频源,即输入源 2、设置输出格式 3、...
    99+
    2022-06-06
    mediarecorder Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作