在本文中,我们将向你展示如何在Debian 10上通过一台主服务器和一台从属服务器配置MariaDB主/从复制,MariaDB是Debian中MySQL的默认实现,相同的步骤适用于Oracle MySQL。这种类型的复制拓扑最适合于部署只读副本以进行规模扩展,实时数据库备份以进行灾难恢复以及分析作业。MySQL复制是将数据从一个数据库服务器(主服务器)复制到一个或多个服务器(从属服务器)的过程。MySQL支持几种复制拓扑,其中主/从拓扑是最著名的拓扑之一,其中一台数据库服务器充当主服务器,而一台或多台服务器充当从属服务器,默认情况下,复制是异步的,其中主服务器向其二进制日志发送描述数据库修改的事件,而从服务器在事件准备就绪时请求事件。
先决条件 我们假设你有两台运行Debian 10的服务器,它们通过专用网络相互通信,如果你的托管服务提供商不支持私有IP地址,则可以使用公共IP地址并将防火墙配置为仅允许来自受信任来源的3306端口上的流量。 本示例中使用的服务器具有以下IP地址: 主IP:10.10.8.12 从站IP:10.10.8.164
安装MariaDB 默认的Debian 10存储库包括MariaDB 10.3版本,最好在两台服务器上安装相同的MariaDB版本,以避免任何潜在的问题。 通过执行以下命令,在主服务器和从服务器上安装MariaDB: $ sudo apt-get update $ sudo apt-get install mariadb-server 参考:在Debian 10(Buster)上安装MariaDB 10.4的方法。
配置主服务器 第一步是设置主服务器,我们将进行以下更改: 1、设置MariaDB服务器以侦听专用IP。 2、设置唯一的服务器ID。 3、启用二进制日志记录。 打开MariaDB配置文件并取消注释或设置以下行: $ sudo nano /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查询以创建一个名为副本的用户,并向该用户授予REPLICATION SLAVE特权: mysql> CREATE USER 'replica'@'10.10.8.164' IDENTIFIED BY 'replica_password'; mysql> GRANT REPLICATION SLAVE ON *.* TO 'replica'@'10.10.8.164'; 确保使用从属IP地址更改IP,你可以根据需要命名用户。 仍在MySQL提示符下时,执行以下命令,该命令将打印二进制文件名和位置。 mysql> SHOW MASTER STATUS\G
注意文件名“ mysql-bin.000001”和位置“ 328”,这些值在配置从属服务器时是必需的,并且在你的服务器上可能会有所不同。
配置从服务器 我们将在从属服务器上进行与主服务器相同的更改: 1、设置MySQL服务器以侦听专用IP。 2、设置唯一的服务器ID。 3、启用二进制日志记录。 打开MariaDB配置文件并编辑以下行: $ sudo nano /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 首先停止从属线程: mysql> STOP SLAVE; 运行以下查询以配置主/从复制: mysql> CHANGE MASTER TO mysql> MASTER_HOST='10.10.8.12', mysql> MASTER_USER='replica', mysql> MASTER_PASSWORD='replica_password', mysql> MASTER_LOG_FILE='mysql-bin.000001', mysql> MASTER_LOG_POS=328; 确保使用正确的IP地址、用户名和密码,日志文件的名称和位置必须与你从主服务器获得的值相同。 完成后,启动从属线程。 mysql> START SLAVE;
测试配置 此时,你应该具有有效的主/从复制设置。 要验证所有设置是否正确,请在主服务器上创建一个新数据库: $ sudo mysql mysql> CREATE DATABASE replicatest; 登录到从属MySQL Shell: $ sudo mysql 运行以下命令: mysql> SHOW DATABASES; 你会注意到,你在主服务器上创建的数据库已在从服务器上复制:
结论 在本文中,我们讲解了在Debian 10服务器上创建MariaDB主/从复制及相关技术点,并且在配置后测试成功。
相关主题 |