Centos7.8下实现MySQL5.7主主互备
Mysql主主互备是在基于主从备份的基础上,从节点也是主节点,实现两者互相以对方为参考系实现rsync操作。
Mysql的三种复制模式
1、基于语句的复制,主服务器上执行的SQL语句在从服务器上同样执行;
2、基于行的复制,把改变的内容复制过去,而不是把命令在服务器上执行一遍;
3、混合类型复制,默认基于语句的复制,一旦发现语句无法精确复制的时候采用基于行的复制。
Mysql主从解决的问题
1、负载均衡,当我们一个集群多个从节点时,可通过第三方技术,例如LVS实现负载均衡;
2、数据备份,当主节点发生数据的改变时,从节点自动备份保证数据安全
3、高可用性和容错性
4、读写分离
Mysql主从复制的原理
Master服务器数据发生改变时,Master服务器将改变的记录写入二进制binlog日志中>>Slave服务器定时探测其日志文件是否发生改变,若改变>>Slave服务器开始I/O Thread请求Master服务器的二进制事件>>主节点为每个I/O线程启动一个Dump线程,向Slave服务器发送二进制事件,并保存在从节点本地的中继日志中>>从节点启动SQL Thread从中继日志中读取二进制日志>>Slave节点重放二进制日志,实现数据同步>>I/O Thread和SQL Thread进入睡眠等待唤醒。
Mysql主主互备搭建
在两台安装了Mysql的环境下进行,值得注意的是,一般只要跟同步相关的操作几乎都需要NTP实现时间同步。
环境
操作系统:centos7.8 2003
Master1:192.168.2.21 heetok.learning.com
Master2:192.168.2.22 heetok2.learning.com
已安装NTP、Mysql
添加同步用户以及分配权限
#all-nodes
CREATE USER 'replication'@'%' IDENTIFIED BY 'Replication@1';
GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';
修改配置文件/etc/my.cnf
#all-nodes
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
character_set_server=utf8
collation-server=utf8_general_ci
symbolic-links=0
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
#set master-master env
log_bin=master-bin
log_bin_index=master-bin.index
server-id=4
expire-logs-days=7
binlog_ignore_db=mysql
binlog_ignore_db=information_schema
binlog_ignore_db=performation_schema
binlog_ignore_db=sys
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index
查看master状态并把自己当作从服务器指向对方为主服务器
#all-nodes
#重启mysqld
systemctl restart mysqld
#all-nodes
查看master状态
show master status;
#master1-node
#更改主服务器
change master to master_host='192.168.2.22', master_port=3306, master_user='replication',
master_password='Replication@1', master_log_file='master-bin.000001', master_log_pos=154;
#master2-node
#更改服务器
change master to master_host='192.168.2.21', master_port=3306, master_user='replication',
master_password='Replication@1', master_log_file='master-bin.000001', master_log_pos=154;
启动从服务器
#all-nodes
start slave;
show slave status\G
测试
master1服务器创建名为heetok1的数据库,里面表为heetok1,然后插入姓名heetok1,年龄21
master2服务器查看数据库内容并且插入姓名heetok2,年龄22
master1服务器查看两者同步
综上所述,两个服务器已经互为主从,实现数据库主主互备的搭建。
如有不妥,敬请指正~