生产环境中常用的一种数据库备方式,适用于组建热备及高可用
用途和用条件
mysql主从复制用途
- 实时灾备,用于故障切换
- 读写分离,提供查询服务
- 备份,避免影响业务
主从部署必要条件:
- 主库开启binlog日志(设置log-bin参数)
- 主从server-id不同
- 从库服务器能连通主库
//注:关闭selinux ,firewall
主从原理
mysql主从复制原理
![](https://i-blog.csdnimg.cn/blog_migrate/4a4d2e0eb5f889a91cbbb61dd5cc1848.png)
从库生成两个线程,一个I/O线程,一个SQL线程;
i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中;
主库会生成一个 log dump 线程,用来给从库 i/o线程传binlog;
在没开启log_slave_updates时, Replay log的记录操作不会写进binlog里.
SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致;
同步模式
主从常见架构
-- 基本应用
单向复制:主 --> 从
-- 扩展应用
链式复制:主 --> 从 --> 从
双向复制:主 <--> 从
放射式复制:从 <-- 主 --> 从
&