Mycat实现Mysql主从复制和读写分离

一、环境要求

      跟着上一篇博客的环境:

    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文件:

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

          <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="database1"></schema>  

        <dataNode name="database1" dataHost="localhost1" database="master" />  

        <dataHost name="localhost1" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="2"  slaveThreshold="100">  
                <heartbeat>show slave status</heartbeat>  
                <writeHost host="cluster1" url="192.168.137.16:3306" user="root" password="root">  
                        <readHost host="slave1" url="192.168.137.17:3306" user="root" password="root" />  
                </writeHost>  
                <writeHost host="cluster2" url="192.168.137.17:3306" user="root" password="root" />
        </dataHost>  

</mycat:schema>

 

      配置server.xml:

<user name="user">
    <property name="password">user</property>
    <property name="schemas">TESTDB</property>
    <property name="readOnly">false</property>
</user>

      说明:

      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

登陆演示mycat

登陆

登录方式类似于 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之前,需要先检查一些配置:

  1. java的版本需要是1.7或以上;

  2. Mysql的配置文件需要加一行lower_case_table_names = 1[mysqld]栏目中,这个设置为Mysql大小写不敏感,否则可能会发生表找不到的问题;

  3. 在示例的2个数据节点上,新建3个数据库相关数据库,如不新建,可能提示找不到数据库ERROR 3009 (HY000): java.lang.IllegalArgumentException: Invalid DataSource:0这个提示不够友好,是在运行很长一段时间后才提示);

  4. ERROR 3009 (HY000): java.lang.IllegalArgumentException: Invalid DataSource:1

    这个有可能是Mycat和MySQL部署在同一台机器上,而在schema.xml是使用了IP的,但是账号只能使用localhost登陆,所以会出现本地的Mycat无法连接MySQL

  5. 添加MYCAT_HOME环境变量指向解压的mycat目录,主要是为了一些bin目录下的脚本的使用。

 三、Mycat性能监控

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

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值