Linux(3)—— 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进入睡眠等待唤醒。

img

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服务器查看两者同步

在这里插入图片描述

综上所述,两个服务器已经互为主从,实现数据库主主互备的搭建。

如有不妥,敬请指正~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值