如何在Ubuntu 18.04上配置MySQL主从复制

栏目: 数据库 · 发布时间: 5年前

内容简介:MySQL复制是一个允许来自一个数据库服务器的数据自动复制到一个或多个服务器的过程。MySQL支持许多复制拓扑,其中主/从拓扑是一个最着名的拓扑之一,其中一个数据库服务器充当主服务器,而一个或多个服务器充当从服务器。默认情况下,复制是异步的,其中主服务器将描述数据库修改的事件发送到其二进制日志,并且从服务器在准备好时请求事件。本教程介绍了在Ubuntu 18.04上使用一个主服务器和一个从服务器进行MySQL主/从复制的基本示例。同样的步骤适用于MariaDB。

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

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

本教程介绍了在Ubuntu 18.04上使用一个主服务器和一个从服务器进行 MySQL 主/从复制的基本示例。同样的步骤适用于MariaDB。

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

必要条件

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

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

Master IP(主服务器IP): 192.168.100.190

Slave IP(从服务器IP):  192.168.100.236

安装MySQL

默认的Ubuntu 18.04存储库包含MySQL 5.7版。 为避免出现任何问题,最好在两台服务器上安装相同的MySQL版本。

在Master服务器上安装MySQL:

sudo apt-get update

sudo apt-get install mysql-server

使用相同的命令在Slave服务器上安装MySQL:

sudo apt-get update

sudo apt-get install mysql-server

配置主服务器

第一步是配置主MySQL服务器。 我们将进行以下更改:

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

为此,请打开MySQL配置文件并取消注释或设置以下内容:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

master:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address          = 192.168.100.190

server-id              = 1

log_bin                = /var/log/mysql/mysql-bin.log

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

sudo systemctl restart mysql

下一步是创建一个新的复制用户。 键入以下内容以root用户身份登录MySQL服务器:

sudo mysql

在MySQL提示符内,运行以下 SQL 查询,这些查询将创建副本用户并向用户授予REPLICATION SLAVE权限:

CREATE USER 'replica'@'192.168.100.236' IDENTIFIED BY 'replica_password';

GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.100.236';

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

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

SHOW MASTER STATUS\G

输出:

*************************** 1. row ***************************

File: mysql-bin.000001

Position: 629

Binlog_Do_DB:

Binlog_Ignore_DB:

Executed_Gtid_Set:

1 row in set (0.00 sec)

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

配置从属服务器

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

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

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

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

slave:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address          = 192.168.100.236

server-id              = 2

log_bin                = /var/log/mysql/mysql-bin.log

重启MySQL服务:

sudo systemctl restart mysql

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

sudo mysql

首先,停止slave线程:

STOP SLAVE;

运行以下查询,该查询将设置从服务器来复制主服务器:

CHANGE MASTER TO

MASTER_HOST='192.168.100.190',

MASTER_USER='replica',

MASTER_PASSWORD='replica_password',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=629;

确保使用正确的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)

总结

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

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

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

本文永久更新链接地址: https://www.linuxidc.com/Linux/2019-05/158696.htm


以上所述就是小编给大家介绍的《如何在Ubuntu 18.04上配置MySQL主从复制》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java Web服务:构建与运行

Java Web服务:构建与运行

Martin Kalin / 任增刚 / 电子工业出版社 / 2009年11月 / 45.00元

本书以示例驱动的方式详尽地介绍了XML Web服务(JAX-WS)和RESTful Web服务(JAX-RS)二者所涵盖的Java相关API。 《Java Web服务:构建和运行》这本书以清晰、务实的方法讲述Web服务相关技术,提供了混合性的架构总结、完全可以运行的代码示例,以及编译、部署和执行应用程序的一些短小精悍的指令。学习本书,读者将掌握如何从零开始编写Web服务或将已有的服务整合到现......一起来看看 《Java Web服务:构建与运行》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换