如何在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 mysqldsudo systemctl start mysqld
首次启动MySQL服务器时,将为MySQL根用户生成一个临时密码。
要查找密码,请使用以下grep命令:
sudo grep 'temporary password' /var/log/mysqld.log
运行“ mysql_secure_installation”命令来设置新的root密码并提高MySQL实例的安全性:
mysql_secure_installation
输入临时的root密码,然后对所有问题回答“是”(是)。
新密码的长度至少应为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提示符内,运行以下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;
登录到从MySQLshell程序:
mysql -uroot -p
运行以下命令以列出所有数据库:
SHOW DATABASES;
我们会注意到,我们在主服务器上创建的数据库已在从服务器上复制:
+--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | replicatest | | sys | +--------------------+ 5 rows in set (0.00 sec)