MySQL读写分离

一:一主一从

1.原理:

MySQL的主从复制,是基于二进制日志(binlog)实现的。

2.环境准备

后续步骤参考主从复制的搭建

二:一主一从读写分离

1.配置

MyCat控制后台数据库的读写分离和负载均衡由schema.xml文件datahost标签的balance属性控制。

2.测试

连接Mycat,并在Mycat中执行DML、DQL查看是否能够进行读写分离。

问题:主节点Master宕机之后,业务系统就只能够读,而不能写入数据了。

三:双主双从

1.介绍

一个主机Master1用于处理所有写请求,它的从机Slave1和另一台主机Master2还有它的从机Slave2负责所有读请求。当Master1主机宕机后,Master主机负责写请求,Master1、Master2互为备机。架构图如下:

2.准备工作

我们需要准备五台服务器,具体的服务器及软件安装情况如下:

关闭以上所有服务器的防火墙:

systemctl stop firewalld

systemctl disable firewalld

3.主库配置(Master1-192.168.200.211/Master2-192.168.200.213)

①修改配置文件/etc/my.cnf

#mysql服务ID、保证整个集群环境中唯一、取值范围:1 - 232-1,默认为1

server-id=1/3

#指定同步的数据库

binlog-do-db=db01

binlog-do-db=db02

binlog-do-db=db03

#在作为从数据库的时候,有写入操作也要更新二进制文件

log-slave-updates

②重启MySQL服务器

systemctl restart mysqld

4.从库配置(Slave1-192.168.200.212/Slave2-192.168.200.214)

①修改配置文件/etc/my.cnf

#mysql服务器ID,保证整个集群环境中唯一,取值范围:1 - 232-1,默认为1

server-id=2/4

②重启MySQL服务器

systemctl restart mysqld

5.两台从库配置关联的主库

CHANGE MASTER TO MASTE_HOST='xxx.xxx.xxx.xxx',MASTER_USER='xxx',MASTER_PASSWORD='xxx',MASTER_LOG_FILE='xxx',MASTER_LOG_POS=xxx;

需要注意slave1对应的是master1,slave2对应的是master2。

启动两台从库主从复制,查看从库状态

start slave;

show slave status \G;

6.两台主库互相复制

Master2复制Master1,Master1复制Master2

CHANGE MASTER TO MASTE_HOST='xxx.xxx.xxx.xxx',MASTER_USER='xxx',MASTER_PASSWORD='xxx',MASTER_LOG_FILE='xxx',MASTER_LOG_POS=xxx;

启动两台从库主从复制,查看从库状态

art slave;

show slave status \G;

7.测试

分别在两台主库Master1、Master2上执行DDL、DML语句,查看涉及到的数据库服务器的数据同步情况。

四:两主两从读写分离

1.配置

MyCat控制后台数据库的读写分离和负载均衡由schema.xml文件和datahost标签的balance属性控制,通过writeType及SwitchType来完成失败自动切换的。

balance="1"

代表全部的readHost与stand by writeHost 参与select语句的负载均衡,简单的说,当双主从模式(M1->S1,M2->S2),并且M1与M2互为主备,正常情况下,M2,S1,S2都参与select语句的负载均衡;

writeType

0:写操作都转发到第1台writeHost,writeHost1挂了,会切换到writeHost2上;

1:所有的写操作都随机地发送到配置的writeHost上;

SwitchType

-1:不自动切换主库

1:自动切换主库

2.测试

登录MyCat,测试查询及更新操作,判定是否能够进行读写分离,以及读写分离的策略是否正确。当主库挂掉一个之后,是否能够自动切换。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值