一、环境要求
跟着上一篇博客的环境:
Centos 7
jdk-8u131-linux-x64.rpm
Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
mysql
Navicat数据库管理工具
设计思路:建立两个数据库,分别存放在192.168.137.16 和192.168.137.17,这两个数据库有相同的数据库版本,主从同步的数据库名字相同都为master。其中16上的master库为主库,负责写入操作。17上的master库为从库,负责读取操作。
二、使用mycat配置Mysql读写分离
2.1 读写分离配置
当MySQL按照之前的主从复制方式配置好集群以后,可以开启Mycat的读写分离机制,Mycat 1.4 支持MySQL主从复制状态绑定的读写分离机制,让读更加安全可靠,以以下的配置为例,表明一个从节点hostS1与一个主节点hostM1组成了标准的一主一从的读写分离模式:
修改schema.xml文件:
配置server.xml:
说明:
balance:决定了哪些MySQL服务器参与到读SQL的负载均衡中,
0为不开启读写分离
1为全部的readHost与standby writeHost参与select语句的负载均衡
比如我们配置了1主3从的MySQL主从环境,并把第一个从节点MySQL配置为dataHost中的第二个writeHost,以便主节点宕机后,Mycat自动切换到这个writeHost上来执行写操作,此时balance=1就意味着第一个writeHost不参与读SQL的负载均衡,其他3个都参与;
balance=2则表示所有的writeHost不参与,此时,只有2个readHost参与负载均衡。这里有一个细节需要你知道,readHost是从属于writeHost的,即意味着它从那个
writeHost获取同步数据,因此,当它所属的writeHost宕机了,则它也不会再参与到读写分离中来,即“不工作了”,这是因为
此时,它的数据已经“不可靠”了。基于这个考虑,目前mycat 1.3和1.4版本中,若想支持MySQL一主一从的标准配置,并且在
主节点宕机的情况下,从节点还能读取数据,则需要在Mycat里配置为两个writeHost并设置banlance=1。
WriteType参数设置:
writeType=“0”, 所有写操作都发送到可用的writeHost上。
writeType=“1”,所有写操作都随机的发送到readHost。
writeType=“2”,所有写操作都随机的在writeHost、readhost分上发。
“readHost是从属于writeHost的,即意味着它从那个writeHost获取同步数据,因此,当它所属的writeHost宕机了,则它也不会再参与到读写分离中来,即“不工作了”,这是因为此时,它的数据已经“不可靠”了。基于这个考虑,目前mycat 1.3和1.4版本中,若想支持MySQL一主一从的标准配置,并且在主节点宕机的情况下,从节点还能读取数据,则需要在Mycat里配置为两个writeHost并设置banlance=1。”
switchType 目前有三种选择:
-1:表示不自动切换
1 :默认值,自动切换
2 :基于MySQL主从同步的状态决定是否切换
“Mycat心跳检查语句配置为 show slave status ,dataHost 上定义两个新属性: switchType=”2” 与slaveThreshold=”100”,此时意味着开启MySQL主从复制状态绑定的读写分离与切换机制。Mycat心跳机制通过检测 show slave status 中的 “Seconds_Behind_Master”, “Slave_IO_Running”, “Slave_SQL_Running” 三个字段来确定当前主从同步的状态以及Seconds_Behind_Master主从复制时延。“
2.2
登陆
登录方式类似于 mysql 的服务端登陆,目前 mycat 有两个端口,8066 数据端口,9066 管理端口
登陆方式如:
mysql -h127.0.0.1 -utest -ptest -P9066 [-dmycat]
-h 后面是主机,即当前 mycat 按照的主机地址,本地可用 127.0.0.1 远程需要远程 ip
-u Mycat server.xml 中配置的逻辑库用户
-p Mycat server.xml 中配置的逻辑库密码
-P 后面是端口 默认 9066,注意 P 是大写
-d Mycat server.xml 中配置的逻辑库
数据端口与管理端口的配置端口修改:
数据端口默认 8066,管理端口默认 9066 ,如果需要修改需要配置 serve.xml
演示
D:\mycat\bin>mysql -utest -ptest -P9066 -Dtestdb
mysql> show @@help; -- 获取有关管理的相关命令
mysql> show @@database; -- 查看逻辑数据库
+----------+
| DATABASE |
+----------+
| testdb |
+----------+
mysql> show @@datanode; --查看分片节点
mysql> show @@server; --查看服务器状态
mysql> show @@version; --查看版本
+----------------------------------------+
| VERSION |
+----------------------------------------+
| 5.5.8-mycat-1.4-RELEASE-20150922233010 |
+----------------------------------------+
D:\mycat\bin>mysql -utest -ptest -P8066 -Dtestdb
mysql> select database();
+------------+
| DATABASE() |
+------------+
| testdb |
+------------+
mysql> show tables;
+------------------+
| Tables in TESTDB |
+------------------+
| company |
| customer |
| customer_addr |
| employee |
| goods |
| hotnews |
| orders |
| order_items |
| travelrecord |
+------------------+
启动MyCAT之前,需要先检查一些配置:
java的版本需要是1.7或以上;
Mysql的配置文件需要加一行lower_case_table_names = 1
在[mysqld]
栏目中,这个设置为Mysql大小写不敏感,否则可能会发生表找不到的问题;
在示例的2个数据节点
上,新建3个数据库相关数据库
,如不新建,可能提示找不到数据库ERROR 3009 (HY000): java.lang.IllegalArgumentException: Invalid DataSource:0
(这个提示不够友好,是在运行很长一段时间后才提示);
ERROR 3009 (HY000): java.lang.IllegalArgumentException: Invalid DataSource:1
这个有可能是Mycat和MySQL部署在同一台机器上,而在schema.xml是使用了IP的,但是账号只能使用localhost登陆,所以会出现本地的Mycat无法连接MySQL
添加MYCAT_HOME
环境变量指向解压的mycat目录,主要是为了一些bin
目录下的脚本的使用。
三、Mycat性能监控
支持对Mycat、Mysql性能监控
支持对Mycat的JVM内存提供监控服务
支持对线程的监控
支持对操作系统的CPU、内存、磁盘、网络的监控
1)下载WEB管理端软件
wget https://github.com/MyCATApache/Mycat-download/blob/master/mycat-web-1.0/Mycat-web-1.0-SNAPSHOT-20160617163048-linux.tar.gz
2)需要安装zookeeper
[root@mysql-m local]# wget http://mirrors.hust.edu.cn/apache/zookeeper/zookeeper-3.4.6/zookeeper-3.4.6.tar.gz
[root@mysql-m local]# tar zxf zookeeper-3.4.6.tar.gz
[root@mysql-m local]# ln -s zookeeper-3.4.6 zookeeper
[root@mysql-m conf]# cp zoo_sample.cfg zoo.cfg
[root@mysql-m bin]# ./zkServer.sh start
JMX enabled by default
Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
[root@mysql-m ~]# lsof -i :2181
安装WEB管理端
[root@mysql-m bin]# cd /usr/local/
[root@mysql-m local]# tar zxf Mycat-web-1.0-SNAPSHOT-20160617163048-linux.tar.gz
[root@mysql-m local]# cd mycat-web/mycat-web/WEB-INF/classes/
[root@mysql-m classes]# vim mycat.properties
#
#Mon Jan 16 15:37:36 CST 2012
show.period=3000000
zookeeper=10.0.0.11:2181
[root@mysql-m mycat-web]# /usr/local/mycat-web/start.sh &
[1] 3684
[root@mysql-m mycat-web]# nohup: ignoring input and appending output to `nohup.out'
[root@mysql-m mycat-web]# lsof -i :8082