MySQL复制是将数据从一个数据库服务器/主服务器复制到一个或多个服务器/从属服务器的过程。MySQL支持几种复制拓扑,其中主/从拓扑是最著名的拓扑之一,一台数据库服务器充当主服务器,而另一台或多台服务器充当从属服务器。

默认情况下,复制是异步的,其中主服务器发送描述数据库修改的事件到从服务器,这些事件通常是二进制日志。而从服务器在事件准备就绪时处理事件。

在本教程中,我们将向您展示如何在Debian 10上通过一台主master服务器和一台从属slave服务器设置MariaDB主/从复制。MariaDB是Debian中MySQL的默认实现。相同的步骤适用于Oracle MySQL。包括安装MariaDB,启动mysql的二进制日志,配置主服务器,配置从服务器,测试配置,创建独立复制用户。

这种复制拓扑最适合部署只读副本以进行扩展读取,实时数据库备份以进行恢复和分析作业。

先决条件

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

本示例中使用的服务器具有以下IP地址:

Master IP: 10.10.8.12
Slave IP:  10.10.8.164

安装MariaDB

默认的Debian 10存储库包括MariaDB版本10.3。最好在两个服务器上安装相同的 MariaDB版本,以避免任何潜在的问题。通过以下命令在主服务器和从服务器上安装MariaDB

sudo apt-get update
sudo apt-get install mariadb-server

配置主服务器

第一步是设置主服务器。我们将设置MariaDB服务器以监听专用的IP。设置唯一的服务器ID。启用二进制日志记录。使用你喜欢的编辑器,打开MariaDB配置文件,在本教程我们将使用vim编辑器

sudo vim /etc/mysql/mariadb.conf.d/50-server.cnf

取消以下几行的注释:

bind-address           = 10.10.8.12
server-id              = 1
log_bin                = /var/log/mysql/mysql-bin.log
/etc/mysql/mariadb.conf.d/50-server.cnf

完成后,保存文件并重新启动MySQL服务以使更改生效:

sudo systemctl restart mariadb

下一步是创建一个新的replica用户。以root用户登录MariaDB服务器:

sudo mysql

运行以下SQL查询以创建名为replica的用户,并将该用户REPLICATION SLAVE的权限授予该用户:

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

请确保将10.10.8.164 IP地址更改为你的IP地址。您可以根据需要命名用户。

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

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

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

配置从服务器

我们将在从属服务器上进行与主服务器相同的更改。包括设置MySQL服务器监听专用IP。设置唯一的服务器ID。启用二进制日志记录。

打开MariaDB配置文件,然后编辑以下几行:

sudo vim /etc/mysql/mariadb.conf.d/50-server.cnf

取消以下几行的注释:

bind-address           = 10.10.8.164
server-id              = 2
log_bin                = /var/log/mysql/mysql-bin.log
/etc/mysql/mariadb.conf.d/50-server.cnf

重新启动MariaDB服务:

sudo systemctl restart mariadb

下一步是配置从属服务器连接到主服务器的参数。执行以下命令登录到从服务器的MariaDB shell:

sudo mysql

首先停止SLAVE进程:

STOP SLAVE;

运行以下查询以配置主/从复制:

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

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

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)

结论

在本教程中,我们显示了在Debian 10上创建MariaDB主/从复制。如有任何疑问,请随时发表评论。