centos 7 mysql主从复制_如何在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.rpm

sudo yum install mysql-community-server

安装完成后,启动MySQL服务,并使其能够在启动时自动通过以下方式启动:sudo systemctl enable mysqld

sudo systemctl start mysqld

首次启动MySQL服务器时,将为MySQL根用户生成一个临时密码。要找到密码,请使用以下grep命令:sudo grep 'temporary password' /var/log/mysqld.log

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

输入临时root密码,然后对所有问题回答Y(是)。

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

配置主服务器

首先,我们将配置主MySQL服务器并进行以下更改:设置唯一的服务器ID。

启用二进制日志记录。

为此,请打开MySQL配置文件,并在[mysqld]部分中添加以下行:sudo nano /etc/my.cnf

master:/etc/my.cnfbind-address = 192.168.121.59

server-id = 1

log_bin = mysql-bin

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

下一步是创建一个新的复制用户。以root用户身份登录到MySQL服务器:mysql -uroot -p

在MySQL提示中,运行以下SQL查询,这些查询将创建replica用户并向该用户授予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.cnfbind-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 TO

MASTER_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 -pCREATE DATABASE replicatest;

登录到从MySQL外壳程序:mysql -uroot -p

运行以下命令以列出所有数据库:SHOW DATABASES;

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

| Database |

+--------------------+

| information_schema |

| mysql |

| performance_schema |

| replicatest |

| sys |

+--------------------+

5 rows in set (0.00 sec)

结论

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值