mysql集群--读写分离

版权声明:本文为博主原创文章,未经博主允许不得转载。否则切鸡鸡~~ https://blog.csdn.net/kang5789/article/details/70810349

结构图如下:

机器列表:

master1:192.168.66.11

slave1:   192.168.66.12

mycat1:    192.168.66.13

mycat2:    192.168.66.14

master2: 192.168.66.17

slave2:    192.168.66.18

 

 

我们要实现的效果是,写操作在master1,读操作在剩余三台机器,maser1挂掉之后写操作切换到master2。

双主双备数据同步,请看上篇文章  点击打开链接   

 

首先自己安装jdk,此处省略解压   tar -zxvf mycat.gz  配置环境变量

vi /etc/profile
## mycat env
export MYCAT_HOME=/usr/local/mycat
export PATH=$PATH:$MYCAT_HOME/bin
# source /etc/profile

1、在配置 MyCat 前,请确认 MySQL 的主从复制安装配置已完成并正常运行。MySQL 主从数
据的同步在 MySQL 中配置,MyCat 不负责数据同步的问题。
补充:
(1) MySQL 主从复制配置中,如果涉及到函数或存储过程的同步复制,需要在/etc/my.cnf 中
的[mysqld]段中增加配置 log_bin_trust_function_creators=true 或在客户端中设置 set global
log_bin_trust_function_creators = 1;
(2) 如果要做读写分离下的主从切换,那么从节点也有可能会变为写节点,因此从节点就不
能设置为只读 read_only=1 。
(3) Linux 版本的 MySQL,需要设置为 MySQL 大小写不敏感,否则可能会发生找不到表的问
题。可在/etc/my.cnf 的[mysqld]段中增加 lower_case_table_names=1 。
2、配置 MyCat 的 schema.xml
schema.xml 是 MyCat 最重要的配置文件之一,用于设置 MyCat 的逻辑库、表、数据节点、
dataHost 等内容,
$ cd /usr/local/mycat/conf/

$ vi schema.xml

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://org.opencloudb/">

        <!-- 1、定义MyCat的逻辑库TESTDB,并且绑定数据节点datanode1 -->
       <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="datanode1"></schema>

        <!-- 2、定义MyCat的数据节点,链接的是机器列表dtHost1上的数据库mars -->
        <dataNode name="datanode1" dataHost="dtHost1" database="mars" />

        <!-- 注意:schema中的每一个dataHost中的host属性值必须唯一,否则会出现主从在所有dataHost中全部切换的现象。 -->
        <!-- 定义数据主机dtHost1,只连接到MySQL读写分离集群中的Master节点,不使用MyCat托管MySQL主从切换 -->
        <!-- 使用MyCat托管MySQL主从切换 -->
        <!-- 3、定义数据主机dtHost1,连接到MySQL读写分离集群,并配置了读写分离和主从切换 -->
        <dataHost name="dtHost1" maxCon="500" minCon="20" balance="1"
                writeType="0" dbType="mysql" dbDriver="native" switchType="2" slaveThreshold="100">
                <writeHost host="m1" url="192.168.66.11:3306" user="root" password="123456">
                        <readHost host="s1" url="192.168.66.12:3306" user="root" password="123456" />
                </writeHost>
                <writeHost host="m2" url="192.168.66.17:3306" user="root" password="123456">
                        <readHost host="s2" url="192.168.66.18:3306" user="root" password="123456" />
                </writeHost>
        </dataHost>
        <!-- 参数balance决定了哪些MySQL服务器参与到读SQL的负载均衡中 -->
        <!-- balance="0",为不开启读写分离,所有读操作都发送到当前可用的writeHost上-->
        <!-- balance="1",全部的readHost与stand by writeHost参与select语句的负载均衡-->
        <!-- balance="2",所有读操作都随机的在writeHost、readHost上分发-->
        <!-- MyCat1.4版本中,若想支持MySQL一主一从的标准配置,并且在主节点宕机的情况下,从节点还能读取数据,
             则需要在MyCat里配置为两个writeHost并设置balance="1" -->
        <!-- writeType="0",所有写操作发送到配置的第一个writeHost,第一个挂了切到还生存的第二个writeHost-->
        <!-- writeType="1",仅仅对于galera for mysql集群这种多主多节点都能写入的集群起效,此时Mycat会随机选择一个writeHost并写入数据,
             对于非galera for mysql集群,请不要配置writeType=1,会导致数据库不一致的严重问题 -->

</mycat:schema>balance="1",全部的readHost与stand by writeHost参与select语句的负载均衡-->
        <!-- balance="2",所有读操作都随机的在writeHost、readHost上分发-->
        <!-- MyCat1.4版本中,若想支持MySQL一主一从的标准配置,并且在主节点宕机的情况下,从节点还能读取数据,
             则需要在MyCat里配置为两个writeHost并设置balance="1" -->
        <!-- writeType="0",所有写操作发送到配置的第一个writeHost,第一个挂了切到还生存的第二个writeHost-->
        <!-- writeType="1",仅仅对于galera for mysql集群这种多主多节点都能写入的集群起效,此时Mycat会随机选择一个writeHost并写入数据,
             对于非galera for mysql集群,请不要配置writeType=1,会导致数据库不一致的严重问题 -->

</mycat:schema>

红色标识的是重点,这样配置可以满足,写操作在master1,读操作在剩余三台机器,maser1挂掉之后写操作切换到master2。

3、配置 server.xml

server.xml 主要用于设置系统变量、管理用户、设置用户权限等。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mycat:server SYSTEM "server.dtd">
<mycat:server xmlns:mycat="http://org.opencloudb/">
        <system>
        <property name="defaultSqlParser">druidparser</property>
        <property name="charset">utf8mb4</property>
        </system>

        <!-- 用户1,对应的MyCat逻辑库连接到的数据节点对应的主机为MySQL主从复制配置中的Master节点,
             没实现读写分离,读写都在该Master节点中进行  -->
        <!--
        <user name="user1">
                <property name="password">123456</property>
                <property name="schemas">rc_schema1,pay_schema1</property>
        </user>
        -->

        <!-- 用户2,对应的MyCat逻辑库连接到的数据节点对应的主机为主从复制集群,并通过MyCat实现了读写分离 -->
        <user name="user2">
                <property name="password">123456</property>
                <property name="schemas">TESTDB</property>
        </user>

        <!-- 用户3,只读权限-->
        <user name="user3">
                <property name="password">123456</property>
                <property name="schemas">TESTDB</property>
                <property name="readOnly">true</property>
        </user>

</mycat:server>

4、防火墙中打开 8066 和 9066 端口
MyCat 的默认数据端口为 8066,mycat 通过这个端口接收数据库客户端的访问请求。
管理端口为 9066,用来接收 mycat 监控命令、查询 mycat 运行状况、重新加载配置文件等。
# vi /etc/sysconfig/iptables
增加:
## MyCat
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8066 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 9066 -j ACCEPT
重启防火墙:
 service iptables restart
5、修改 log 日志级别为 debug,以便通过日志确认基于 MyCat 的 MySQL 数据库集群读写分
离的数据操作状态(可以在正式上生产前改成 info 级别)
$ vi /usr/local/mycat/conf/log4j.xml
6、启动 MyCat
$ cd /usr/local/mycat/bin/
(1) 控制台启动,这种启动方式在控制台关闭后,MyCat 服务也将关闭,适合调试使用:
$ ./mycat console
(2) 可以采用以下后台启动的方式:
$ ./mycat start
Starting Mycat-server...
(对应的,重启: mycat restart , 关闭: mycat stop )

测试:直接用数据库连接工具navicat连接即可。

192.168.66.11    master1

192.168.66.12    slave1

展开阅读全文

没有更多推荐了,返回首页