MySQL复制是一种过程,它允许将来自一个数据库服务器的数据自动复制到一个或多个服务器。

MySQL支持多种复制拓扑,其中主/从拓扑是最著名的拓扑之一,其中一台数据库服务器充当主服务器,而一个或多个服务器充当从属服务器。默认情况下,复制是异步的,其中主服务器向其二进制日志发送描述数据库修改的事件,而从服务器在事件准备就绪时请求事件。

本教程介绍了在Ubuntu 18.04上使用一个主服务器和一个从属服务器进行MySQL主/从复制的基本示例。相同的步骤适用于MariaDB。

这种类型的复制拓扑最适合于部署只读副本以进行规模扩展,实时数据库备份以进行灾难恢复和分析工作。

先决条件

此示例假设您有两台运行Ubuntu 18.04的服务器,它们可以通过专用网络相互通信。如果您的托管服务提供商不提供私有IP地址,则可以使用公共IP地址并配置防火墙,以仅允许来自受信任来源的端口3306上的流量。

此示例中的服务器具有以下IP:

Master IP: 192.168.121.190
Slave IP:  192.168.121.236

安装MySQL

默认的Ubuntu 18.04存储库包括MySQL 5.7版。为了避免出现任何问题,最好在两个服务器上安装相同的 MySQL版本

在主服务器上安装MySQL

sudo apt-get update
sudo apt-get install mysql-server

使用相同的命令在从服务器上安装MySQL:

sudo apt-get update
sudo apt-get install mysql-server

配置主服务器

第一步是配置主MySQL服务器。我们将进行以下更改:

为此,请打开MySQL配置文件并取消注释或设置以下内容:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

主:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address           = 192.168.121.190
server-id              = 1
log_bin                = /var/log/mysql/mysql-bin.log

完成后,重新启动MySQL服务以使更改生效:

sudo systemctl restart mysql

下一步是创建一个新的复制用户。通过键入以下内容以root用户身份登录到MySQL服务器:

sudo mysql

在MySQL提示中,运行以下SQL查询,这些查询将创建replica用户并向该用户授予REPLICATION SLAVE特权:

CREATE USER 'replica'@'192.168.121.236' IDENTIFIED BY 'replica_password';
GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.121.236';

请确保使用从IP地址更改IP。您可以根据需要命名用户。

仍在MySQL提示符内时,执行以下命令,以打印二进制文件名和位置。

SHOW MASTER STATUS\G
*************************** 1. row ***************************
             File: mysql-bin.000001
         Position: 629
     Binlog_Do_DB: 
 Binlog_Ignore_DB: 
Executed_Gtid_Set: 
1 row in set (0.00 sec)

记下文件名'mysql-bin.000001'和位置'629'。配置从属服务器时,需要这些值。这些值在您的服务器上可能会有所不同。

配置从属服务器

就像上面的主服务器一样,我们将对从属服务器进行以下更改:

  • 设置MySQL服务器以侦听私有IP
  • 设置唯一的服务器ID
  • 启用二进制日志记录

打开MySQL配置文件并编辑以下几行:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

从属:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address           = 192.168.121.236
server-id              = 2
log_bin                = /var/log/mysql/mysql-bin.log

重新启动MySQL服务:

sudo systemctl restart mysql

下一步是配置从属服务器将用于连接到主服务器的参数。登录到MySQL Shell:

sudo mysql

首先,停止从属线程:

STOP SLAVE;

运行以下查询,以设置从属服务器复制主服务器:

CHANGE MASTER TO
MASTER_HOST='192.168.121.190',
MASTER_USER='replica',
MASTER_PASSWORD='replica_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=629;

确保使用正确的IP地址,用户名和密码。日志文件的名称和位置必须与您从主服务器获得的值相同。

完成后,启动从属线程。

START SLAVE;

测试配置

这时,您应该有一个有效的主/从复制设置。

为验证一切正常,我们将在主服务器上创建一个新数据库:

sudo mysql
CREATE DATABASE replicatest;

登录到从属MySQL Shell:

sudo mysql

运行以下命令以列出所有数据库

SHOW DATABASES;

您会注意到,您在主服务器上创建的数据库已在从服务器上复制:

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| replicatest        |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

结论

在本教程中,我们向您展示了如何创建MySQL主/从复制。

如有任何疑问,请随时发表评论。

如果你喜欢我们的内容可以选择在下方二维码中捐赠我们,或者点击广告予以支持,感谢你的支持