如何在Debian 10上配置MySQL(MariaDB)主从复制
admin
2023-08-03 05:56:23
0

MySQL复制是将数据从一个数据库服务器(主服务器)复制到一个或多个服务器(从属服务器)的过程。

MySQL支持几种复制拓扑,其中主/从拓扑是最著名的拓扑之一,其中一台数据库服务器充当主服务器,而一台或多台服务器充当从属服务器。默认情况下,复制是异步的,其中主服务器向其二进制日志发送描述数据库修改的事件,而从服务器在事件准备就绪时请求事件。

在本教程中,我们将向您展示如何在Debian 10上通过一台主服务器和一台从属服务器设置MariaDB主/从复制。MariaDB是Debian中MySQL的默认实现。相同的步骤适用于Oracle MySQL。

这种类型的复制拓扑最适合于部署只读副本以进行规模扩展,实时数据库备份以进行灾难恢复以及分析作业。

先决条件

我们假设您有两台运行Debian 10的服务器,它们通过专用网络相互通信。如果您的托管服务提供商不支持私有IP地址,则可以使用公共IP地址并将防火墙配置为仅允许来自受信任源的端口3306上的通信。

本示例中使用的服务器具有以下IP地址:

Master IP: 10.10.8.12
Slave IP:  10.10.8.164

安装MariaDB

默认的Debian 10存储库包括MariaDB版本10.3。最好在两个服务器上安装相同的MariaDB版本,以避免任何潜在的问题。

通过发出以下命令,在主服务器和从服务器上安装MariaDB:

sudo apt-get update
sudo apt-get install mariadb-server

配置主服务器

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

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

打开MariaDB配置文件并取消注释或设置以下行:

sudo nano /etc/mysql/mariadb.conf.d/50-server.cnf

大师:/etc/mysql/mariadb.conf.d/50-server.cnf

bind-address           = 10.10.8.12
server-id              = 1
log_bin                = /var/log/mysql/mysql-bin.log

完成后,保存文件并重新启动MySQL服务以使更改生效:

sudo systemctl restart mariadb

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

sudo mysql

运行以下SQL查询以创建一个名为的用户并向该用户replica授予REPLICATION SLAVE特权:

CREATE USER \'replica\'@\'10.10.8.164\' IDENTIFIED BY \'replica_password\';
GRANT REPLICATION SLAVE ON *.* TO \'replica\'@\'10.10.8.164\';

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

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

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

注意文件名“ mysql-bin.000001”和位置“ 328”。这些值在配置从属服务器时是必需的,并且在您的服务器上可能会有所不同。

配置从服务器

我们将在从属服务器上进行与主服务器相同的更改:

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

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

sudo nano /etc/mysql/mariadb.conf.d/50-server.cnf

奴隶:/etc/mysql/mariadb.conf.d/50-server.cnf

bind-address           = 10.10.8.164
server-id              = 2
log_bin                = /var/log/mysql/mysql-bin.log

重新启动MariaDB服务:

sudo systemctl restart mariadb

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

sudo mysql

首先停止从属线程:

STOP SLAVE;

运行以下查询以配置主/从复制:

CHANGE MASTER TO
MASTER_HOST=\'10.10.8.12\',
MASTER_USER=\'replica\',
MASTER_PASSWORD=\'replica_password\',
MASTER_LOG_FILE=\'mysql-bin.000001\',
MASTER_LOG_POS=328;

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

完成后,启动从属线程。

START SLAVE;

测试配置

此时,您应该有一个正常的主/从复制设置。

要验证所有设置是否正确,请在主服务器上创建一个新数据库:

sudo mysql
CREATE DATABASE replicatest;

登录到从MySQL外壳程序:

sudo mysql

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

SHOW DATABASES;

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

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

 

相关内容

热门资讯

Windows 11 和 10... Windows 11/10 文件夹属性中缺少共享选项卡 – 已修复 1.检查共享选项卡是否可用 右键...
Radmin VPN Wind... Radmin VPN 是一款免费且用户友好的软件,旨在牢固地连接计算机以创建一个有凝聚力的虚拟专用网...
如何修复 Steam 内容文件... Steam 内容文件锁定是当您的 Steam 文件无法自行更新时出现的错误。解决此问题的最有效方法之...
在 Windows 11 中打... 什么是链路状态电源管理? 您可以在系统控制面板的电源选项中看到链接状态电源管理。它是 PCI Exp...
iPhone 屏幕上有亮绿色斑... iPhone 是市场上最稳定的智能手机之一,这主要归功于专为它们设计的 iOS 操作系统。然而,他们...
事件 ID 7034:如何通过... 点击进入:ChatGPT工具插件导航大全 服务控制管理器 (SCM) 负责管理系统上运行的服务的活动...
QQ浏览器怎么制作简历 QQ浏览器是腾讯公司开发的一款极速浏览器,支持电脑,安卓,苹果等多种终端;更快的浏览体验,更安全的浏...
Hive OS LOLMine... 目前不清退的交易所推荐: 1、全球第二大交易所OKX欧意 国区邀请链接: https://www.m...
Apple Watch Ult... 所有运行 watchOS 7 或更高版本的 Apple Watch 型号都包含一项名为“优化电池充电...
统信UOS每次开机后不直接进入... 统信UOS每次开机后不直接进入系统而是进入到recovery模式 按方向上键选择UOS 20 SP1...