结构图如下:
机器列表:
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>
红色标识的是重点,这样配置可以满足,写操作在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