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

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

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

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

必要条件

此示例假设您有两台运行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)

总结

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

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/223560.html<

(0)
运维的头像运维
上一篇2025-04-16 00:45
下一篇 2025-04-16 00:46

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注