MySQL数据库运维学习笔记03

第四章、读写分离

介绍

读写分离,简单地说是把对数据库的读和写操作分开,以对应不同的数据库服务器。主数据库提供写操作,从数据库提供读操作,这样能有效地减轻单台数据库的压力。

通过MyCat即可轻易实现上述功能,不仅可以支持MySQL,也可以支持Oracle和SQL Server。

一主一从

环境准备

主机                         角色    用户名    密码

192.168.200.211    master    root     1234

192.168.200.212      slave     root    1234

主从复制的搭建,可以参考前面记录的笔记进行操作。

一主一从读写分离

配置

schema.xml:

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

<schema name="ITCAST RW" checkSQLschema="true" sqlMaxLinit="100" datqaNode="dn7">

            <! -- <table name="sku" dataNode="dn7" primaryKey="id"/> -- >

</schema>

<dataNode name="dn7" dataHost "dhost7" database="itcast"/>

<dataHost name="dhost7" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="jdbc">

            <heartbeat>select user()</heartbeat>

            <writeHost host="master" url="jdbc:mysql://192.168.200.211: 3306?usesSL=false" user="root" password="1234">

                    <readHost host="slave" url="jdbc:mysql://192.168.200.212 : 3306?usesSL=false" user="root" password="1234"/>

            </writeHost>

</dataHost>

seves.xml:

<user name="root" defaultAccount="true">

          <property name="password">123456</property>

          <property name="schemas">SHOPPING,ITCAST,ITCAST_RW</property>

balance="1" :

负载均衡策略,目前取值有4种

参数值      含义

0     不开启读写分离机制,所有读操作都发送到当前可用的writeHost上

1     全部的readHost与备用的writeHost都参与select语句的负载均衡(主要针对于双主双从模式)

2     所有的读写操作都随机在writeHost,readHost上分发

3     所有的读请求随机分发到writeHost对应的readHost上执行,writeHost不负担读压力

测试

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

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

双主双从

介绍

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

准备工作

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

编号              IP                   预装软件                  角色

1   192.168.200.210      MyCat、MySQL   MyCat中间件服务器

2   192.168.200.211             MySQL                     M1

3   192.168.200.212             MySQL                     S1

4   192.168.200.213             MySQL                     M2

5   192.168.200.214             MySQL                     S2

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

  • systemctl stop firewalld
  • systemctl disable firewalld

搭建

主库配置(Master1-192.168.200.211)

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

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

server-id=1

#指定同步的数据库

binlog-do-db=db01

binlog-do-db=db02

binlog-do-db=db03

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

log-slave-updates

2.重启MySQL服务器

systemctl restart mysqld

主库配置(Master2-192.168,200.213)

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

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

server-id=3

#指定同步的数据库

binlog-do-db=db01

binlog-do-db=db02

binlog-do-db=db03

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

log-slave-updates

2.重启MySQL服务器

systemctl restart mysold

两台主库创建账户并授权

#创建itcast用户,并设置密码,该用户可在任意主机连接该MySQL服务

CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';

#为'itcast'@'%'用户分配主从复制权限

GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';

通过指令,查看两台主库的二进制日志坐标

show master status;

从库配置(Slave1-192.168.200.212)

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

#mysol服务ID,保证整个集群环境中唯一,取值范围:1-2^32-1,默认为1

server-id=2

2.重启MySQL服务器

systemctl restart mysqld

从库配置(Slave2-192.168.200.214)

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

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

server-id=4

2.重启MySQL服务器

systemctl restart mysold

两台从库配置关联的主库

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

(192.168.200.212(S1) :CBANGE MASTBR TO MASTBB_HOST='192.168.200.211', MASTER _USER='itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE=binlog.000002', MASTER_LOG_POS=663;

192.168.200.214(S2):CHANGE MASTER TO MASYBR_HOST='192.168.200.213', MASTER_USER='itcast', MASTER_PASSWORD='Root@123456', MASTBR_LOG _FILE='binlog.000002', MASTER_IOG_POS=663;)

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

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

start slave;

show slave status \G;

两台主库相互复制

Master2复制 Master1,Master1 复制 Master2。

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

(192.168.200.211(M1):CHANGE MASTER TO MASTER_HOST='192.166.200.213', MASTER _USER='Itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILEB='binlog.000002', MASTER_LOG_POS=663;

192.168.200.213(M2):CHANGCE MASTER TO MSTBR _HOST='192.168.200.211', MASTER_USER='itcast', MASTER_PASSWORD='ROOt@123456', MASTBR_LOG_FTILE='binlog.000002', MASTER_LOG_POS-663;)

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

start slave;

show slave status \G;

(Slave_IO_Running: Yes

这表示从服务器的IO线程正在运行。IO线程负责从主服务器读取二进制日志,并将其复制到从服务器。

Slave_SQL_Running: Yes

这表示从服务器的SQL线程正在运行。SQL线程负责解析并执行从主服务器接收到的二进制日志中的SQL语句,将其应用到从服务器的数据库中。)

双主双从读写分离

配置

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

schema.xml:

<schema name="ITCAST_RW2" checkSOLschema="true" sqlMaxLimit="100" dataNode="dn7">

         <!--<table name="tb_user" dataNode="dn7" primaryKey="id"/> -- >

</schema>

<dataNode name="dn7" dataHost="dhost7" database="db01"/>

<dataHost name="dhost7" maxCon="1000" minCon="10" balance="1" writeType="0" switchType="1" dbType="mysql" dbDriver="jdbc">

        <heartbeat>select user()</heartbeat>

        <writeHost host="master1" url="jdbc:mysql://192.168.200.211:3306?useSSL=false&:sexverTimezone=Asia/Shangshi" user="root" password="1234">

               <readHost host="slave1" url="jdbc:mysql://192.168.200.212:3306?useSSL=false&:sexverTimezone=Asia/Shangshi" user="root" password="1234">

        </writeHost>   (M1-S1)

        <writeHost host="master2" url="jdbc:mysql://192.168.200.213:3306?useSSL=false&:sexverTimezone=Asia/Shangshi" user="root" password="1234">

               <readHost host="slave2"url="jdbc:mysgl://192.168.200.214:3306?useSSL=falsesamp.serverTimezone=Asia/Shanghai" user="root" password="1234"/>

        </writeHost>   (M2-S2)

</dataHost>

server.xml:

<user name="root" defaultAccount="true">

         <property name="password">123456</property>

         <property name="schemas">SHOPPING, ITCAST, ITCAST_RW2</property>

balance="1"

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

writeType

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

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

switchType

-1:不自动切换

1:自动切换

测试

登录/重启MyCat,测试查询及更新操作,判定是否能够进行读写分离,以及读写分离的策略是否正确。

当主库挂掉一个之后,是否能够自动切换。

总结

1.介绍

读写分离是为了降低单台服务器的访问压力,写走主库,读走从库。

2. 一主一从

MySQL主从复制是基于二进制日志binlog实现的。master、slave

3.一主一从读写分离

<writeHost> <readHost /> <writeHost>、balance属性

4. 双主双从

两台主库,相互复制,互为主备,增强MySQL的可用性。

5.双主双从读写分离

<writeHost> <readHost/> <writeHost>、balance、 writeType、switchType

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值