实战案例:将已有的 MySQL8.0 单机架构变成主从复制架构

操作步骤

  1. 修改 master 主节点 的配置( server-id log-bin )

  2. master 主节点 完全备份( mysqldump )

  3. master 主节点 创建复制用户并授权

  4. master 主节点 将完全备份文件拷贝至从节点

  5. 修改 slave 从节点 的配置( server-id read-only )

  6. 修改 完全备份数据文件( 添加主节点的相关信息 )

  7. slave 从节点 还原备份( souce /data/all.sql )

  8. slave 从节点 开启复制( start slave; )

  9. 验证 主从复制架构

    // 主节点

    修改 master 主节点的配置

    [root@master ~] vim /etc/my.cnf.d/mysql-server.cnf
    [mysqld]
    server-id=8
    log_bin
    log-bin=/data/mysql/logbin/mysql-bin

    [root@master ~] systemctl restart mysqld

    完全备份

    [root@master ~] mysqldump -A -F --master-data=1 --single-transaction > /root/all.sql

    // 创建复制用户并授权

    注意: 修改 IP 地址

    mysql> create user repluser@"192.168.80.%" identified by "123456"
    mysql> grant replication slave on . to repluser@"192.168.80.%"";

    将备份复制到从节点

    [root@master ~] scp /root/all.sql 192.168.80.150:/root

    // 配置从节点
    [root@slave ~] yum install mysql-server -y
    [root@slave ~] vim /etc/my.cnf.d/mysql-server.cnf
    [mysqld]
    server-id=18
    log_bin
    read-only

    [root@slave ~] systemctl enable --now mysqld

    从节点修改备份文件

    [root@centos8 ~] vim /root/all.sql
    CHANGE MASTER TO
    MASTER_HOST='192.168.80.130',
    MASTER_USER='repluser',
    MASTER_PASSWORD='123456',
    MASTER_PORT=3306,
    MASTER_LOG_FILE='mysql-bin.000005', MASTER_LOG_POS=156;

复制代码
# 从节点还原备份
mysql> set sql_log_bin=0;
mysql> source /root/all.sql;
mysql> set sql_log_bin=1;

# 从节点开始主从复制
mysql> start slave;

// 验证线程运行状态 ( 重要 )
mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for source to send event
                  Master_Host: 192.168.80.130
                  Master_User: repluser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000005
          Read_Master_Log_Pos: 367
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 535
        Relay_Master_Log_File: mysql-bin.000005
             Slave_IO_Running: Yes                # 运行中
            Slave_SQL_Running: Yes                # 运行中
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 


// 验证主从同步效果
mysql> drop table coc;     # 主节点删除
mysql> show tables;        # 从节点验证
相关推荐
未来之窗软件服务20 分钟前
JAVASCRIPT 前端数据库-V1--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟数据库
LjQ204028 分钟前
网络爬虫一课一得
开发语言·数据库·python·网络爬虫
烙印60132 分钟前
MyBatis原理剖析(二)
java·数据库·mybatis
RestCloud34 分钟前
如何通过ETLCloud实现跨系统数据同步?
数据库·数据仓库·mysql·etl·数据处理·数据同步·集成平台
你是狒狒吗35 分钟前
TM中,return new TransactionManagerImpl(raf, fc);为什么返回是new了一个新的实例
java·开发语言·数据库
Channing Lewis2 小时前
sql server如何创建表导入excel的数据
数据库·oracle·excel
秃头摸鱼侠2 小时前
MySQL安装与配置
数据库·mysql·adb
UGOTNOSHOT2 小时前
每日八股文6.3
数据库·sql
行云流水行云流水2 小时前
数据库、数据仓库、数据中台、数据湖相关概念
数据库·数据仓库
John Song2 小时前
Redis 集群批量删除key报错 CROSSSLOT Keys in request don‘t hash to the same slot
数据库·redis·哈希算法