zoukankan      html  css  js  c++  java
  • mariadb 读写分离

    实验环境

    以下配置都是建立在mariadb主从没有问题的情况下:

    1.三台主机:

    在三台机器/etc/hosts添加以下3条主机信息
    mycat:192.168.254.24
    hostM1:192.168.254.28
    hostS1:192.168.254.29
    2.需要安装java1.8版本或以上

    3.下载mycat源码包
    (1)wget http://dl.mycat.io/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
    (2)tar -zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
    (3)mv mycat /usr/local/

    mycat配置

    vim /usr/local/mycat/conf/server.xml设置如下参数

    <user name="testuser1">
                    <property name="password">testuser1</property>
                    <property name="schemas">testdb,testdb1</property>
    
                    <!-- 表级 DML 权限设置 -->
                    <!--            
                    <privileges check="false">
                            <schema name="TESTDB" dml="0110" >
                                    <table name="tb01" dml="0000"></table>
                                    <table name="tb02" dml="1111"></table>
                            </schema>
                    </privileges>           
                     -->
            </user>
    
            <user name="testuser2">
                    <property name="password">testuser2</property>
                    <property name="schemas">testdb,testdb1</property>
                    <property name="readOnly">true</property>
            </user>

    #testuser1用来写的用户
    #testuser2用来读的用户
    #testdb是mycat是逻辑库

    vim /usr/local/mycat/conf/schema.xml配置(请先备份cp schema.xml schema.xml.bak,然后把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="1000" dataNode="dn1">
    </schema>
    <schema name="testdb1" checkSQLschema="false" sqlMaxLimit="1000" dataNode="dn2">
    </schema>
    
    <dataNode name="dn1" dataHost="hostM1" database="test" />
    <dataNode name="dn2" dataHost="hostM1" database="test1" />
    <dataHost name="hostM1" maxCon="2000" minCon="1" balance="1" writeType="1" dbType="mysql" dbDriver="native" switchType=
    "1" slaveThreshold="100">
    <heartbeat>select user()</heartbeat>
    <writeHost host="hostM1" url="192.168.254.28:3306" user="testuser1" password="testuser1">
    <readHost host="hostS1" url="192.168.254.29:3306" user="testuser2" password="testuser2" />
    </writeHost>
    </dataHost>
    </mycat:schema>
    

      

    server.xml和schema.xml标绿色处要一致,都是逻辑库,我这里创建了2个逻辑库

    dataHost为数据节点名称,database为真实数据库名称即后台数据库test和test1

    balance:

    0表示不开启读写分离,都在master上执行读写操作

    1表示都参与select

    2表示所有读请求随机在readhost和writehost分担

    3表示所有读请求对应到readhost里去

    writeType

    0,所有写操作发送到配置的第一个writeHost

    1,所有写操作都随机的发送到配置的writeHost

    2,不执行写操作。

    switchType

    -1,不自动切换

    1,默认值,自动切换

    2,基于MySQL 主从同步的状态决定是否切换

    3,基于MySQL galary cluster的切换机制(适合集群)(1.4.1),心跳语句为 show status like &lsquo;wsrep%&rsquo;

    writeHost和readHost分别配置对应后台的mysql主从真实用户密码

    创建用户并赋予权限(主创建同步到从)

    grant all on *.* to testuser1@'%' identified by 'testuser1';
    grant all on *.* to testuser2@'%' identified by 'testuser2';
    

      

    启动mycat服务并查看端口

    /usr/local/mycat/bin/mycat start
    

      

    8066是管理端口

    9066是连接后端数据库的端口,默认是9066,登录该端口后直接用show @@datasource;语句即可查询主从库的读写状态

    mysql -h 192.168.254.24 -P8066 -utestuser1 -ptestuser1    (可以执行增删改查)
    
    mysql -h 192.168.254.24 -P9066 -utestuser1 -ptestuser1     (可以查看节点状态)
    

      

    查看心跳状态

    show @@heartbeatG
    

      

    #查看前端连接状态

    show @@connectionG
    

      

     

    #查看后端状态

    show @@backendG

     

     #查看数据库资源状态

    show @@datasource

     

  • 相关阅读:
    JS中的原型规则与原型链
    JS中的“==”与强制类型转换
    协作开发中常用的Git命令小结
    JavaScript变量类型检测总结
    IDEA IntelliJ常用设置以及快捷键(转)
    Spring 发送 Email
    SSM框架的整合思路&功能实现
    使用Eclipse把java文件打包成jar 含有第三方jar库的jar包
    基于CDH5.x 下面使用eclipse 操作hive 。使用java通过jdbc连接HIVESERVICE 创建表
    Volley源码学习笔记
  • 原文地址:https://www.cnblogs.com/kesz/p/10900387.html
Copyright © 2011-2022 走看看