要搭建MySQL主从复制,需要按照以下步骤进行操作:
-
确保主服务器和从服务器上都已安装MySQL。
-
在主服务器上修改配置文件
my.cnf
,开启二进制日志功能。打开配置文件后,找到[mysqld]
部分,在下面添加以下内容:
server-id = 1 log-bin = /var/log/mysql/mysql-bin.log
server-id
用于标识主服务器的唯一ID,可以设置任意值,但不能与从服务器的ID相同。log-bin
指定二进制日志的路径和文件名。
-
重启主服务器使配置生效。
-
在主服务器上创建用于复制的账号,并赋予复制权限。打开MySQL客户端,执行以下SQL语句:
CREATE USER 'replication'@'从服务器IP地址' IDENTIFIED BY '密码'; GRANT REPLICATION SLAVE ON *.* TO 'replication'@'从服务器IP地址'; FLUSH PRIVILEGES;
将从服务器IP地址
替换为从服务器的实际IP地址,密码
替换为复制账号的密码。
-
在主服务器上执行
SHOW MASTER STATUS;
命令,记录下结果中的File
和Position
的值。 -
在从服务器上修改配置文件
my.cnf
,添加以下内容:
server-id = 2
server-id
用于标识从服务器的唯一ID,可以设置任意值,但不能与主服务器的ID相同。
-
重启从服务器使配置生效。
-
在从服务器上执行以下命令:
STOP SLAVE; CHANGE MASTER TO MASTER_HOST='主服务器IP地址', MASTER_USER='replication', MASTER_PASSWORD='密码', MASTER_LOG_FILE='主服务器上的File值', MASTER_LOG_POS=主服务器上的Position值; START SLAVE;
将主服务器IP地址
替换为主服务器的实际IP地址,密码
替换为复制账号的密码,主服务器上的File值
和主服务器上的Position值
替换为第5步中记录的值。
- 执行
SHOW SLAVE STATUS\G;
命令,查看从服务器的状态,确保Slave_IO_Running
和Slave_SQL_Running
的值都为Yes
,表示复制已成功搭建。
完成上述步骤后,MySQL主从复制就成功搭建起来了。主服务器上的数据更新将自动同步到从服务器上。