主从简介
在现代企业中,数据显得尤为重要,而存储数据的数据库选择又五花八门,但无论是何种数据库,均存在着一种隐患。
当数据规模非常大,读写量也很高时,一台数据库已经无法负担全部读写任务,就需要多台数据库同时运作分担负载。
主从作用
实时灾备,用于故障切换
读写分离,提供查询服务
备份,避免影响业务
主从形式
一主一从
主主复制
一主多从(扩展系统读取的性能,读在从库,写在主库)
多主一从(5.7开始支持)
联级复制
主从复制原理
主从复制步骤:
主库将所有的写操作记录到binlog日志中并生成一个log dump线程,将binlog日志传给从库的I/O线程
从库生成两个线程,一个I/O线程,一个SQL线程
I/O线程去请求主库的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中
SQL线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,达到最终数据一致的目的
传统主从弊端
互为主从时,可能会由于循环写导致数据失去一致性。
主从配置
需求:
搭建两台MySQL服务器,一台作为主服务器,一台作为从服务器,主服务器进行写操作,从服务器进行读操作
环境:
主数据库
CentOS7/RedHat7
IP-192.168.233.129
Hostname-Lynk
有数据
副数据库
CentOS7/RedHat7
IP-192.168.233.247
Hostname-Hyrule
无数据
主从复制配置步骤:
确保从数据库与主数据库里的数据一样
在主数据库里创建一个同步账号授权给从数据库使用
配置主数据库(修改配置文件)
配置从数据库(修改配置文件)
安装数据库
给从库授权
#以下操作在主库进行
mysql> CREATE USER 'repl'@&#