MySQL5.7主从复制详细配置教程

 更新时间:2022年11月02日 08:38:41   作者:youbins  
这篇文章主要介绍了MySQL5.7主从复制详细配置教程的相关资料,需要的朋友可以参考下

1 环境准备

192.168.1.34 服务器A(主机)
192.168.1.35 服务器B(从机)

2 安装mysql

MySQL版本:

这里采用Server version: 5.7.35 MySQL Community Server (GPL)

我们把安装在“服务器A”的数据库称作“主数据库”、安装在“服务器B”的数据库称作“从数据库”。

2.1 开放端口

确保服务器A与服务器B上的3306端口可以互访。

3 设置主库

进行下面的配置前,假设你已经在两台服务器AB上安装成功MySQL服务。

192.168.1.34 服务器A(主机)

3.1 修改MySQL配置文件

编辑mysql配置文件/etc/my.cnf,添加如下的内容:

[mysqld]
log-bin=mysql-bin
server-id=1

保存修改内容并重启MySQL服务。

3.2 创建一个用户用于复制

所谓复制用户,即供从数据库使用的,从主数据库拷贝二进制日志信息的用户。

用客户端连接上MySQL服务,执行以下语句创建一个用于复制的用户:

mysql> CREATE USER 'repl'@'192.168.1.%' IDENTIFIED BY 'Abc!@#123';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.%';

3.3 获取二进制文件位置

这些信息在后面配置从数据库时用到。

1、阻塞数据库写语句

mysql> FLUSH TABLES WITH READ LOCK;

2、获取当前二进制文件的名称和位置

mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |     1030 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

3.4 使用mysqldump创建数据快照

本指南默认使用InnoDB存储引擎。

如果在启用主从复制前,主数据库已存在数据,那么你就需要先把这些数据拷贝到从数据库。下面给出一个例子,将所有数据库备份到一个叫做dbdump.db的文件:

shell> mysqldump --all-databases --master-data > dbdump.db

其中--master-data选项会自动追加 CHANGE MASTER TO语句,该语句在从数据库启动复制进程时需要到。

注意:

如果你没有使用--master-data选项的话,那么你需要在一个单独的会话中锁定所有数据表。详情见 Section 16.1.2.3, “Obtaining the Replication Source's Binary Log Coordinates”.

4 设置从库

192.168.1.35 服务器B(从机)

4.1 修改MySQL配置文件

编辑mysql配置文件/etc/my.cnf,添加如下的内容:

[mysqld]
server-id=2
skip_slave_start=ON

这里主要解释一下skip_slave_start配置,ON表示数据库启动时不启动从机的复制进程,需要通过手动的方式进行启动。

保存修改内容并重启MySQL服务。

4.2 设置从库对应的主库

这里主要用到 CHANGE MASTER TO语句,其基本语法如下:

mysql> CHANGE MASTER TO
    ->     MASTER_HOST='source_host_name',
    ->     MASTER_USER='replication_user_name',
    ->     MASTER_PASSWORD='replication_password',
    ->     MASTER_LOG_FILE='recorded_log_file_name',
    ->     MASTER_LOG_POS=recorded_log_position;

我们的例子对应如下(当中的参数见上文[设置主数据库](#3 设置主数据库)一节):

mysql> CHANGE MASTER TO
    ->     MASTER_HOST='192.168.1.34',
    ->     MASTER_USER='repl',
    ->     MASTER_PASSWORD='Abc!@#123',
    ->     MASTER_LOG_FILE='mysql-bin.000001',
    ->     MASTER_LOG_POS=1030;

4.3 导入全新的数据的情况

即主库和备库都是新建的,不存在旧库旧表旧数据,且主库已经启用二进制日志,备库已指定主库及当前位置。这时你想要将其它的数据库备份下来导入到当前的主备数据库中,你只需要在主库中执行导入命令即可(不能再备库执行导入语句):

shell> mysql -h '192.168.1.34' < fulldb.dump

4.4 主库已存在数据的情况

即主库在启用二进制日志前已存在数据,你在启用从库复制进程前需要把主库的备份快照导入到从库中,然后才能启用从库的复制进程。

1、新建主库快照

shell> mysqldump --all-databases --master-data > dbdump.db

2、导入到从库中

shell&gt; mysql -h '192.168.1.35' &lt; fulldb.dump

4.5 启用从库复制进程

mysql> START SLAVE;

验证主从复制是否启动成功

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.1.34
                  Master_User: repl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 2096
               Relay_Log_File: 192-relay-bin.000007
                Relay_Log_Pos: 320
        Relay_Master_Log_File: mysql-bin.000001
             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: 
......

如上,只有Slave_IO_RunningSlave_SQL_Running同时都是Yes的时候表示主从复制配置成功。

5 互为主从设置

前面两个章节讲了如何配置主从复制,即服务器A的数据库作为主库,服务器B的数据库作为从库;那么只要按照相反的步骤再设置一遍,即服务器B的数据库作为主库,服务器A的数据库作为从库。这样就可以使得服务器A的数据库和服务器B的数据库互为主从了。

到此这篇关于MySQL5.7主从复制详细配置教程的文章就介绍到这了,更多相关MySQL5.7主从复制 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql最新版8.0.17解压版安装教程

    mysql最新版8.0.17解压版安装教程

    这篇文章主要为大家详细介绍了最新版mysql 8.0.17 解压版安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • MySQL Replication中的并行复制示例详解

    MySQL Replication中的并行复制示例详解

    MySQL在5.6版本之前,主从复制的从节点上有两个线程,分别是I/O线程和SQL线程,今天通过本文给大家介绍MySQL Replication中的并行复制示例详解,感兴趣的朋友一起看看吧
    2022-07-07
  • 详解MySQL中存储函数创建与触发器设置

    详解MySQL中存储函数创建与触发器设置

    这篇文章主要为大家详细介绍了MySQL中存储函数的创建与触发器的设置,文中的示例代码讲解详细,具有一定的学习价值,需要的可以参考一下
    2022-08-08
  • Mysql 8.0.18 hash join测试(推荐)

    Mysql 8.0.18 hash join测试(推荐)

    这篇文章给大家介绍Mysql 8.0.18 hash join测试的相关知识,本文通过实例代码讲解,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2019-10-10
  • /var/log/pacct文件导致MySQL启动失败的案例分享

    /var/log/pacct文件导致MySQL启动失败的案例分享

    这篇文章主要介绍了/var/log/pacct文件导致MySQL启动失败的案例分享,这是个比较让人郁闷的问题,找不到MySQL启动失败的原因进可以按此文的方法试一试,需要的朋友可以参考下
    2015-01-01
  • mysql报错Duplicate entry ‘xxx‘ for key ‘字段名‘的解决

    mysql报错Duplicate entry ‘xxx‘ for key&nbs

    有时候对表进行操作,例如加唯一键,或者插入数据,会报错,本文就来介绍一下mysql报错Duplicate entry ‘xxx‘ for key ‘字段名‘的解决方法,感兴趣的可以了解一下
    2023-10-10
  • 正确使用MySQL INSERT INTO语句

    正确使用MySQL INSERT INTO语句

    MySQL数据库是一种小型关系型数据库管理系统,MySQL数据库的优化是MySQL数据库操作过程中非常重要的工作,MySQL数据库的优化能够实现MySQL数据库操作的简便。
    2015-08-08
  • MySQL中的行级锁、表级锁、页级锁

    MySQL中的行级锁、表级锁、页级锁

    这篇文章主要介绍了MySQL中的行级锁、表级锁、页级锁,以及分享了多种避免死锁的方法,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • 详解MySQL中的数据类型和schema优化

    详解MySQL中的数据类型和schema优化

    这篇文章主要介绍了MySQL中的数据类型和schema优化的相关资料,帮助大家更好的理解和学习MySQL的知识,感兴趣的朋友可以了解下
    2020-10-10
  • 虚拟主机MySQL数据库的备份与还原的方法

    虚拟主机MySQL数据库的备份与还原的方法

    虚拟主机MySQL数据库的备份与还原的方法...
    2007-07-07

最新评论