MySQL 复制是将数据从一台数据库服务器(主服务器)复制到一台或多台服务器(从服务器)的过程。
MySQL 支持多种复制拓扑,其中主/从拓扑是最著名的拓扑之一,其中一台数据库服务器充当主服务器,而一台或多台服务器充当从服务器。默认情况下,复制是异步的,主服务器将描述数据库修改的事件发送到其二进制日志,从服务器在准备好时请求事件。
在本指南中,我们将向您展示如何在 Debian 10 上设置具有一主一从服务器的 MariaDB 主/从复制。MariaDB 是 Debian 中 MySQL 的默认实现。相同的步骤适用于 Oracle 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
配置主服务器#
第一步是设置主服务器。我们将进行以下更改:
- Set the MariaDB服务器监听私有IP
.
- 设置唯一的服务器 ID。
- 启用二进制日志记录。
打开 MariaDB 配置文件并取消注释或设置以下行:
sudo nano /etc/mysql/mariadb.conf.d/50-server.cnf
主控:/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
完成后,保存文件并重新启动 MySQL 服务以使更改生效:
sudo systemctl restart mariadb
下一步是创建新的复制用户。以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';
确保使用从属 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 nano /etc/mysql/mariadb.conf.d/50-server.cnf
从站:/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
重新启动 MariaDB 服务:
sudo systemctl restart mariadb
下一步是配置从服务器用于连接主服务器的参数。登录 MariaDB shell:
sudo mysql
首先停止从属线程:
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 地址、用户名和密码。日志文件名和位置必须与您从主服务器获取的值相同。
完成后,启动从属线程。
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 主/从复制。
如果您有任何疑问,请随时发表评论。