千锋Linux教程:37 主从复制配置流程讲解 主服务器有数据
目录:
MySQL复制是一种过程,它允许将来自一个数据库服务器的数据自动复制到一个或多个服务器。
MySQL支持多种复制拓扑,其中主/从拓扑是最著名的拓扑之一,其中一台数据库服务器充当主服务器,而一台或多台服务器充当从属服务器。 默认情况下,复制是异步的,其中主服务器向其二进制日志发送描述数据库修改的事件,而从服务器在事件准备就绪时请求事件。
本教程介绍了在Ubuntu 18.04上具有一个主服务器和一个从服务器的MySQL主/从复制的基本示例。 相同的步骤适用于MariaDB。
这种类型的复制拓扑最适合于部署只读副本以进行规模扩展,实时数据库备份以进行灾难恢复和分析作业。
先决条件
本示例假定您有两台运行Ubuntu 18.04的服务器,它们可以通过专用网络相互通信。 如果您的托管服务提供商不提供私有IP地址,则可以使用公共IP地址并将防火墙配置为仅允许来自受信任源的端口3306上的流量。
本示例中的服务器具有以下IP:
Master IP: 192.168.121.190 Slave IP: 192.168.121.236
安装MySQL
默认的Ubuntu 18.04存储库包含MySQL版本5.7。 为了避免任何问题,最好在两个服务器上安装相同的MySQL版本。
在主服务器上安装MySQL:
sudo apt-get update
sudo apt-get install mysql-server
使用相同的命令在从服务器上安装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
大师:/etc/mysql/mysql.conf.d/mysqld.cnf
bind-address = 192.168.121.190 server-id = 1 log_bin = /var/log/mysql/mysql-bin.log
完成后,重新启动MySQL服务以使更改生效:
sudo systemctl restart mysql
下一步是创建一个新的复制用户。 通过键入以下内容以root用户身份登录到MySQL服务器:
sudo mysql
在MySQL提示符内,运行以下SQL查询,这些查询将创建
replica
用户并向该用户授予
REPLICATION SLAVE
特权:
CREATE USER 'replica'@'192.168.121.236' IDENTIFIED BY 'replica_password';
GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.121.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设置唯一的服务器IDEnable二进制日志记录
打开MySQL配置文件并编辑以下行:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
奴隶:/etc/mysql/mysql.conf.d/mysqld.cnf
bind-address = 192.168.121.236 server-id = 2 log_bin = /var/log/mysql/mysql-bin.log
重新启动MySQL服务:
sudo systemctl restart mysql
下一步是配置从属服务器将用于连接到主服务器的参数。 登录到MySQL Shell:
sudo mysql
首先,停止从属线程:
STOP SLAVE;
运行以下查询,该查询将设置从属服务器复制主服务器:
CHANGE MASTER TO
MASTER_HOST='192.168.121.190',
MASTER_USER='replica',
MASTER_PASSWORD='replica_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=629;
确保使用正确的IP地址,用户名和密码。 日志文件的名称和位置必须与您从主服务器获得的值相同。
完成后,启动从属线程。
测试配置
此时,您应该具有有效的主/从复制设置。
为了验证一切正常,我们将在主服务器上创建一个新数据库:
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主/从复制。
如有任何疑问,请随时发表评论。
Ubuntu MySQL的MariaDB如何配置mysql master
MySQL复制是一种过程,它使您可以自动将数据从一个数据库服务器复制到一个或多个服务器。 在本教程中,我们将说明如何在CentOS 7上使用一台主服务器和一台从属服务器设置MySQL主/从复制。
如何配置mysql(mariadb)master
在本指南中,我们将向您展示如何在Debian 10上通过一台主服务器和一台从属服务器设置MariaDB主/从复制。MariaDB是Debian中MySQL的默认实现。







