如何在 CentOS 7 上配置 MySQL 主从复制

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

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

在本教程中,我们将解释如何在 CentOS 7 上使用一个主服务器和一个从服务器设置 MySQL 主/从复制。相同的步骤适用于 MariaDB 。

此类复制拓扑最适合部署用于读取扩展的只读副本,用于灾难恢复和分析作业的实时数据库备份。

先决条件

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

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

Master IP: 192.168.121.59
Slave IP:  192.168.121.14

安装 MySQL

默认的 CentOS 7 存储库不包含 MySQL 包,因此我们将从其官方 Yum 存储库安装 MySQL 。为避免任何问题,我们将在两台服务器上安装相同的 MySQL 5.7 版。

在主服务器和从服务器上安装 MySQL :

sudo yum localinstall https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpmsudo 
yum install mysql-community-server

安装完成后,启动 MySQL 服务并启用它以在启动时自动启动:

sudo systemctl enable mysqld
sudo systemctl start mysqld

当 MySQL 服务器第一次启动时,会为 MySQL root 用户生成临时密码。要查找密码,请使用以下 grep 命令

sudo grep 'temporary password' /var/log/mysqld.log

运行该 mysql_secure_installation 命令设置新的 root 密码,提高 MySQL 实例的安全性:

mysql_secure_installation

输入临时 root 密码并在所有问题回答 Y( 是)。

新密码长度必须至少为8个字符,并且至少包含一个大写字母,一个小写字母,一个数字和一个特殊字符。

配置主服务器

首先,我们将配置主 MySQL 服务器并进行以下更改:

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

为此,请打开 MySQL 配置文件,并在以下 [mysqld] 部分添加以下行:

sudo nano /etc/my.cnf

主: /etc/my.cnf

bind-address           = 192.168.121.59
server-id              = 1
log_bin                = mysql-bin

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

sudo systemctl restart mysqld

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

mysql -uroot -p

在 MySQL 提示符内,运行以下将创建 replica 用户的 SQL 查询并将 REPLICATION SLAVE 权限授予用户:

CREATE USER 'replica'@'192.168.121.14' IDENTIFIED BY 'strong_password';
GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.121.14';

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

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

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

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

配置从属服务器

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

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

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

sudo nano /etc/my.cnf

从站: /etc/my.cnf

bind-address           = 192.168.121.14
server-id              = 2
log_bin                = mysql-bin

重启 MySQL 服务:

sudo systemctl restart mysqld

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

mysql -uroot -p

首先,停止从属线程:

STOP SLAVE;

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

CHANGE MASTER TOMASTER_HOST='192.168.121.59',MASTER_USER='replica',MASTER_PASSWORD='strong_password',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=1427;

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

完成后,启动从属线程。

START SLAVE;

测试配置

此时,您有了一个正常工作的主/从复制设置。

要验证一切是否按预期工作,我们将在主服务器上创建一个新数据库

mysql -uroot -p
CREATE DATABASE replicatest;

登录到从属 MySQL shell :

mysql -uroot -p

列出 MySQL 数据库:

SHOW DATABASES;

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

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

结论

在本教程中,我们展示了您在 CentOS 7 上创建 MySQL 主/从复制。