码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MySQL双主模式(2022/11/19)


    MySQL双主模式(2022/11/19)

    文章目录

    • MySQL双主模式(2022/11/19)
      • 一、搭建环境
      • 二、搭建过程
        • 2.1 MySQL 服务安装
        • 2.2 binlog 开启
        • 2.3 创建节点用户
        • 2.4 关联主从节点
        • 2.5 测试是否成功

    本文将介绍如何搭建 MySQL 双主模式,互为主从,均可读写。

    一、搭建环境

    • CentOS Linux release 7.8.2003;
    • Docker version 20.10.14;
    • MySQL Ver 14.14 Distrib 5.7.40;

    二、搭建过程

    2.1 MySQL 服务安装

    此处笔者两台服务器的 IP 地址分别为 172.20.2.2 与 172.20.2.3,接下来将通过 Docker 分别在两台服务器上启动 MySQL 服务。

    # 创建工作目录
    $ mkdir -p /data/mysql
    
    $ cd /data/mysql
    
    # 启动 MySQL 服务
    $ docker run --name mysql -itd --restart always \
    -p 3306:3306 \
    -v $PWD/config:/etc/mysql \
    -v $PWD/data:/var/lib/mysql \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -e LANG=C.UTF-8 \
    -e TZ=Asia/Shanghai \
    --log-driver json-file \
    --log-opt max-size=1g \
    --log-opt max-file=3 \
    mysql:5.7 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --lower_case_table_names=1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2.2 binlog 开启

    # 在 172.20.2.2. 节点进行以下配置
    # 编辑 $PWD/config/mysql.conf.d/mysqld.cnf 文件,不存在则手动创建,添加以下内容
    $ mkdir -p $PWD/config/mysql.conf.d && vim $PWD/config/mysql.conf.d/mysqld.cnf
    [mysqld]
    server-id=1
    
    auto_increment_offset=1
    auto_increment_increment=2
    
    binlog-format=row
    expire_logs_days=7
    log-bin=/var/lib/mysql/mysql-bin.log
    log-slave-updates=true
    sync_binlog=0
    
    gtid-mode=on
    enforce-gtid-consistency=true
    
    replicate-ignore-db=mysql
    replicate-ignore-db=information_schema
    replicate-ignore-db=performance_schema
    replicate-ignore-db=sys
    
    # 重启 MySQL
    $ docker restart mysql
    
    # 在 172.20.2.3 节点进行以下配置
    # 编辑 $PWD/config/mysql.conf.d/mysqld.cnf 文件,不存在则手动创建,添加以下内容
    $ mkdir -p $PWD/config/mysql.conf.d && vim $PWD/config/mysql.conf.d/mysqld.cnf
    [mysqld]
    server-id=2
    
    auto_increment_offset=2
    auto_increment_increment=2
    
    binlog-format=row
    expire_logs_days=7
    log-bin=/var/lib/mysql/mysql-bin.log
    log-slave-updates=true
    sync_binlog=0
    
    gtid-mode=on
    enforce-gtid-consistency=true
    
    replicate-ignore-db=mysql
    replicate-ignore-db=information_schema
    replicate-ignore-db=performance_schema
    replicate-ignore-db=sys
    
    # 重启 MySQL
    $ docker restart mysql
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51

    注意:

    1. server-id 为每个节点的标识,不可重复;
    2. auto_increment_offset 与 auto_increment_increment 指定了 172.20.2.2 节点自增主键为奇数、172.20.2.3 节点自增主键为偶数,避免使用自增主键两节点同时写入时主键产生冲突;

    2.3 创建节点用户

    # 在 172.20.2.2 节点进行以下配置
    $ docker exec -it mysql mysql -uroot -p
    > CREATE USER master1@172.20.2.3 IDENTIFIED BY '123456';
    > GRANT REPLICATION SLAVE ON *.* TO master1@172.20.2.3;
    > FLUSH PRIVILEGES;
    
    # 在 172.20.2.3 节点进行以下配置
    $ docker exec -it mysql mysql -uroot -p
    > CREATE USER master2@172.20.2.2 IDENTIFIED BY '123456';
    > GRANT REPLICATION SLAVE ON *.* TO master2@172.20.2.2;
    > FLUSH PRIVILEGES;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    2.4 关联主从节点

    # 在 172.20.2.2 节点进行以下配置
    $ docker exec -it mysql mysql -uroot -p
    > CHANGE MASTER TO MASTER_HOST='172.20.2.3', MASTER_PORT=3306, MASTER_USER='master2', MASTER_PASSWORD='123456', MASTER_AUTO_POSITION=1;
    > START SLAVE;
    > SHOW SLAVE STATUS\G;
    # 看到以下输出表示成功
    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes
    
    # 在 172.20.2.3 节点进行以下配置
    $ docker exec -it mysql mysql -uroot -p
    > CHANGE MASTER TO MASTER_HOST='172.20.2.2', MASTER_PORT=3306, MASTER_USER='master1', MASTER_PASSWORD='123456', MASTER_AUTO_POSITION=1;
    > START SLAVE;
    > SHOW SLAVE STATUS\G;
    # 看到以下输出表示成功
    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2.5 测试是否成功

    # 在 172.20.2.2 节点创建 test 数据库
    $ docker exec -it mysql mysql -uroot -p
    > CREATE DATABASE IF NOT EXISTS `test` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
    
    # 在 172.20.2.3 节点查看是否存在 test 数据库
    $ docker exec -it mysql mysql -uroot -p
    > SHOW DATABASES;
    
    # 在 172.20.2.3 节点删除 test 数据库
    $ docker exec -it mysql mysql -uroot -p
    > DROP TABLE IF EXISTS `test`;
    
    # 在 172.20.2.2 节点查看是否还存在 test 数据库
    $ docker exec -it mysql mysql -uroot -p
    > SHOW DATABASES;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    参考链接:

    • MySQL双主(主主)架构方案 - ygqygq2 - 博客园 (cnblogs.com)
    • Mysql主从同步的实现原理与配置实战 - 知乎 (zhihu.com)
    • MySQL主从同步详解与配置 - 知乎 (zhihu.com)
    • slave复制进程不随mysql启动而启动 skip-slave-start参数_aeolus_pu的博客-CSDN博客
    • MySQL主从复制,启动slave时报错Slave failed to initialize relay log info structure from the repository_无知的蜗牛的博客-CSDN博客_data for column ‘relay_log_name’ too long
    • 故障案例:主从同步报错Fatal error: The slave I/O thread stops because master and slave have equal MySQL server_胡儿胡儿的博客-CSDN博客
  • 相关阅读:
    IDC Incast 的不彻底解决
    I3C bus
    Php“梦寻”淘宝天猫商品详情数据接口,淘宝商品详情数据API接口,淘宝API接口申请指南(含代码示例)
    Spring MVC注解Controller源码流程解析--映射建立
    “华远新能源”:光伏产业链发展持续向好
    树莓派基金会近日发布了新版基于 Debian 的树莓派操作系统
    LeetCode:2. 两数之和
    目标检测系列算法:YOLOv6代码复现
    如何下载修复xinput1_3.dll并避免常见错误 ,详解多种实用解决方法
    Jasypt加解密、信息脱敏
  • 原文地址:https://blog.csdn.net/qq_44797987/article/details/127940090
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号