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 不同、日志位置要对。连不上多半是网络或配置问题。

相关推荐
卤炖阑尾炎3 小时前
MySQL 故障排查与生产环境优化实战指南
数据库·mysql
一叶飘零_sweeeet4 小时前
击穿 MySQL InnoDB MVCC 底层:从 undo log、Read View 到隔离级别的全链路深度拆解
mysql·innodb·mvcc
前进的李工4 小时前
MySQL大小写规则与存储引擎详解
开发语言·数据库·sql·mysql·存储引擎
殷紫川5 小时前
MySQL 锁等待与死锁根治全攻略:从底层原理到 innodb status 精准定位实战
mysql
MaCa .BaKa5 小时前
44-校园二手交易系统(小程序)
java·spring boot·mysql·小程序·maven·intellij-idea·mybatis
无小道5 小时前
Mysql——索引
mysql·索引·搜索
元宝骑士6 小时前
深度解析 ROW_NUMBER() 窗口函数:从入门到实战避坑指南
后端·mysql
014-code6 小时前
MySQL 常用业务 SQL
数据库·sql·mysql
y = xⁿ7 小时前
【MySQL】数据库的脏读,不可重复读和幻读,覆盖索引是什么,索引类型有哪些
数据库·mysql