MySQL主从复制

一、主从复制是啥?

简单说:

让一台数据库(主)的数据,自动复制到另一台或多台数据库(从)上,实现数据备份、分担查询压力。


二、怎么复制的?------ 三个步骤

  1. 主库记录操作日志

    主库把所有的写操作(增、删、改)记到一个叫"二进制日志"的文件里。

  2. 从库拉取日志

    从库有一个叫 IO 线程 的"搬运工",它去主库把二进制日志搬回来,存到自己本地的"中继日志"里。

  3. 从库执行日志

    从库还有一个叫 SQL 线程 的"执行工",它读取中继日志里的操作,在自己这边重新执行一遍。

最终结果: 从库和主库数据保持一致。


三、搭建主从复制需要做什么?

1. 基础环境准备(主库和从库都要做)

  • 时间同步:用阿里云的 NTP 服务,保证两台机器时间一致。

  • 关防火墙和 SELinux:避免网络不通。

2. 主库配置

  • 开启二进制日志

  • 设置 server-id(唯一标识)

  • 创建一个专门给从库用的账号(比如 slave

  • 查看当前日志文件和位置,记住它(从库要用)

3. 从库配置

  • 设置 server-id(不能和主库一样)

  • 启动 MySQL

  • 告诉从库:"主库在哪、账号密码、从哪个日志文件的哪个位置开始复制"

  • 启动 slave 角色

  • 查看状态,确认 IO 线程和 SQL 线程都是 Yes


四、常见问题(尤其是 IO 线程连不上)

现象:
Slave_IO_Running: Connecting
Last_IO_Error: Can't connect to MySQL server

原因:

  • 网络不通(防火墙、IP 写错)

  • 主库账号密码不对

  • 日志文件名或位置写错了

解决:

  • 检查网络和防火墙

  • 确认主库能正常访问

  • 必要时用 reset replica; 重置从库的复制状态


一句话总结

主从复制就是主库写日志,从库把日志搬回来再执行一遍,最终两边数据一样。搭建时注意时间同步、网络通、server-id 不同、日志位置要对。连不上多半是网络或配置问题。

相关推荐
李白客5 小时前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6002 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL2 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二5 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐6 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
云技纵横6 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神6 天前
三、用户与权限管理
数据库·mysql