导读:本期聚焦于小伙伴创作的《如何配置MySQL主从服务器实现数据同步》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何配置MySQL主从服务器实现数据同步》有用,将其分享出去将是对创作者最好的鼓励。

MySQL主从复制是常用的数据库架构方案,通过主库记录数据变更,从库拉取并回放变更日志实现数据同步,既可以扩展读能力,也能作为数据备份的重要手段。下面我们就一步步完成主从服务器的配置。

如何配置MySQL主从服务器实现数据同步

一、配置前准备

我们需要准备两台安装了同版本MySQL的服务器,这里假设主库IP为192.168.0.10,从库IP为192.168.0.11,确保两台服务器之间网络互通,且MySQL服务正常运行。

二、主库配置步骤

1. 修改主库配置文件

打开主库的MySQL配置文件(一般是/etc/my.cnf或者/etc/mysql/my.cnf),添加以下配置:

[mysqld]
# 开启binlog日志,主从复制依赖binlog传递数据变更
log-bin=mysql-bin
# 设置server-id,主从库的id必须唯一
server-id=1
# binlog格式,推荐使用ROW格式,数据一致性更好
binlog_format=ROW
# 需要同步的数据库,不配置则同步所有库(排除系统库)
binlog-do-db=test_db

修改完成后重启MySQL服务,让配置生效。

2. 创建主从同步账号

登录主库MySQL,创建一个用于从库连接的账号,并授予复制权限:

-- 创建同步账号,允许从库IP连接
CREATE USER 'repl_user'@'192.168.0.11' IDENTIFIED BY 'repl_password';
-- 授予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'192.168.0.11';
-- 刷新权限
FLUSH PRIVILEGES;

3. 查看主库状态

执行以下命令查看主库的binlog信息,记录下FilePosition的值,后续从库配置需要用到:

SHOW MASTER STATUS;

正常输出会类似如下内容,假设File为mysql-bin.000001,Position为154:

FilePositionBinlog_Do_DBBinlog_Ignore_DB
mysql-bin.000001154test_db

三、从库配置步骤

1. 修改从库配置文件

打开从库的MySQL配置文件,添加以下配置:

[mysqld]
# 设置从库唯一的server-id
server-id=2
# 开启relay_log,用于存储从主库拉取的binlog日志
relay_log=mysql-relay-bin
# 设置只读,避免从库被误写入数据(超级权限用户除外)
read_only=1

修改完成后重启从库MySQL服务。

2. 配置主库连接信息

登录从库MySQL,执行以下命令配置主库的连接参数,替换成你实际的主库IP、同步账号、之前记录的File和Position值:

CHANGE MASTER TO
MASTER_HOST='192.168.0.10',
MASTER_USER='repl_user',
MASTER_PASSWORD='repl_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=154;

3. 启动从库同步线程

执行以下命令启动从库的IO线程和SQL线程:

START SLAVE;

4. 检查从库同步状态

执行以下命令查看从库状态:

SHOW SLAVE STATUS\G

重点关注两个参数:Slave_IO_RunningSlave_SQL_Running,如果两者都是Yes,说明主从同步配置成功。

四、验证同步效果

我们在主库的test_db数据库中创建一张表并插入数据:

USE test_db;
CREATE TABLE user_info (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50) NOT NULL,
    age INT
);
INSERT INTO user_info (name, age) VALUES ('张三', 25);

然后登录从库查询user_info表,如果能看到刚才插入的数据,说明主从同步正常工作。

五、常见问题排查

  • 如果从库Slave_IO_Running为Connecting,检查主从网络是否互通、同步账号权限是否正确、主库防火墙是否开放3306端口。
  • 如果Slave_SQL_Running为No,查看Last_SQL_Error字段的报错信息,一般是主从数据不一致导致,需要先修复数据再重启同步线程。
  • 主库重启后,从库会自动重连,不需要手动重新配置,除非主库的binlog被清理导致Position失效。

MySQL_Replication主从同步binlogrelay_log数据备份修改时间:2026-05-30 00:23:13

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。