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

相关推荐
神仙别闹18 小时前
基于Python(Django)+MySQL 实现(Web)SQL智能检测系统的设计与实现
python·mysql·django
tongyiixiaohuang21 小时前
技术案例分享:金蝶云星空客户数据同步到MySQL的实现
android·数据库·mysql
运维全栈笔记21 小时前
K8S部署WordPress+MySQL:模块化YAML配置详解
服务器·mysql·docker·云原生·容器·kubernetes·服务发现
Rick19931 天前
mysql 慢查询如何快速定位
数据库·mysql
Vect__1 天前
MySQL的数据类型和约束
android·数据库·mysql
ChoSeitaku1 天前
5.MySQL表的约束|空属性|默认值|列描述|主键|自增长|唯一键|外键
android·数据库·mysql
A_aspectJ1 天前
【Java基础开发】基于 Java Swing +MySQL + JDBC 版实现图书管理系统
java·开发语言·mysql
小菜同学爱学习1 天前
突破瓶颈!MySQL高级优化与企业级实战场景详解
android·数据库·mysql
小肝一下1 天前
1. 数据库基础(重点)初阶
数据库·mysql
两点王爷1 天前
使用命令行备份/还原docker运行的数据库 (MySQL、PostgreSQL)
mysql·docker·容器