mycat简单使用

database

MyCat

MyCAT是使用JAVA语言进行编写开发,使用前需要先安装JAVA运行环境(JRE),由于MyCAT中使用了JDK7中的一些特性,所以 要求必须在JDK7以上的版本上运行。

mysql

mysql主从复制

首先安装mysql数据库实现主从复制,之前有写过搭建基于Docker的Mysql主从复制搭建

Mycat中间件安装、配置和测试

mycat安装

wget http://dl.mycat.org.cn/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

tar -zvxf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

解压之后mycat下面文件夹  bin  catlet  conf  lib  logs  version.txt     目录解释如下:

bin 程序目录              ./mycat start启动/stop停止/restart重启/status查看状态

conf目录下存放配置文件             server.xml是Mycat服务器参数调整和用户授权的配置文件             schema.xml是逻辑库定义和表以及分片定义的配置文件             rule.xml是分片规则的配置文件,分片规则的具体一些参数信息单独存放为文件,也在这个目录下             配置文件修改,需要重启Mycat

lib目录下主要存放mycat依赖的一些jar文件         日志存放在logs/mycat.log中,每天一个文件,日志的配置是在conf/log4j.xml中         可以根据自己的需要,可以调整输出级别为debug,debug级别下,会输出更多的信息,方便排查问题.

Mycat相关配置

修改schema.xml配置文件(这里简单的读写分离配置)

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

<schema name="test" checkSQLschema="false" sqlMaxLimit="100" dataNode="haha">         </schema> # 一个<schema >相当于一个数据库;name:逻辑库名称;dataNode对应<dataNode>的name     <dataNode name="haha" dataHost="Mycat-node" database="test" />

<dataHost name="Mycat-node" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">         <heartbeat>show slave status</heartbeat>         <writeHost host="Mysql-node1" url="localhost:3339" user="root" password="123456">              <readHost host="Mysql-node2" url="localhost:3340" user="root" password="123456">              </readHost>         </writeHost>         <writeHost host="Mysql-node2" url="localhost:3340" user="root" password="123456">         </writeHost>     </dataHost>     </mycat:schema>

还需要修改对应的server.xml中的配置文件

# mycat的访问端口配置

<property name="serverPort">8066</property> <property name="managerPort">9066</property>

# mycat用户密码配置相关信息

 <user name="root">

                <property name="password">123456</property>

                <property name="schemas">test</property> #此处为数据库配置文件<schema>名称

                <!-- 表级 DML 权限设置 -->

                <!--

                <privileges check="false">

                        <schema name="test" dml="0110" >

                                <table name="tb01" dml="0000"></table>

                                <table name="tb02" dml="1111"></table>

                        </schema>

                </privileges>

                 -->

        </user>

        <user name="user">

                <property name="password">user</property>

                <property name="schemas">test</property>

                <property name="readOnly">true</property>

        </user>

强制走写节点(加在sql语句前)

/*#mycat:db_type=master*/

对于<dataHost>标签,它里面重要的参数列举如下:

balance指的负载均衡类型,目前的取值有4种:

1. balance=”0”, 不开启读写分离机制,所有读操作都发送到当前可用的writeHost上。

2. balance=”1”,全部的readHost与stand bywriteHost参与select语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且M1与 M2互为主备),正常情况下,M2,S1,S2都参与select语句的负载均衡。

3. balance=”2”,所有读操作都随机的在writeHost、readhost上分发。

4. balance=”3”,所有读请求随机的分发到wiriterHost对应的readhost执行,writerHost不负担读压力

注意:balance=3只在1.4及其以后版本有,1.3没有。

writeType属性:

1.writeType=”0”,所有写操作发送到配置的第一个writeHost,第一个挂了切到还生存的第二个writeHost,重新启动后以切换后的为准,切换记录在配置文件中:dnindex.properties.

2.writeType=”1”,所有写操作都随机地发送到配置的writeHost,1.5以后废弃不推荐。

switchType指的是切换的模式,目前的取值也有4种:

1. switchType=’-1’ 表示不自动切换

2. switchType=’1’ 默认值,表示自动切换

3. switchType=’2’ 基于MySQL主从同步的状态决定是否切换,心跳语句为 show slave status

4. switchType=’3’基于MySQLgalary cluster的切换机制(适合集群)(1.4.1),心跳语句为 show status like ‘wsrep%’。

注意:估计Mycat1.4才开始支持switchType。1.3版本配置该属性的话,日志里会报错:org.xml.sax.SAXParseException;lineNumber: 61; columnNumber: 86; Attribute “switchType” must bedeclared for element type “dataHost”。

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主从复制时延,当Seconds_Behind_Master>slaveThreshold时,读写分离筛选器会过滤掉此Slave机器,防止读到很久以前的旧数据,当主节点宕机后,切换逻辑会检查Slave上的Seconds_Behind_Master是否为0,为0时则表示主仅同步,可安全切换,否则不会切换。

mycat分库分表配置

<?xml version="1.0"?>

<!DOCTYPE mycat:schema SYSTEM "schema.dtd">

<mycat:schema xmlns:mycat="http://io.mycat/">

    <schema name="TESTDB" checkSQLschema="true" sqlMaxLimit="100" dataNode="haha" >

        <table name="t_user" dataNode="db_1,db_2,haha" rule="crc32slot" ></table># name为被拆分的表名称 rule为拆分规则 对应在rule.xml文件中进行修改 

    </schema>

        <dataNode name="db_1" dataHost="Mycat-node" database="db_one" /> #表拆分之后存放的数据库1

        <dataNode name="db_2" dataHost="Mycat-node" database="db_two" /> #表拆分之后存放的数据库2

        <dataNode name="haha" dataHost="Mycat-node" database="test" /> #表拆分之后存放的数据库3

<dataHost name="Mycat-node" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">

    <heartbeat>show slave status</heartbeat>

    <writeHost host="Mysql-node1" url="localhost:3339" user="root" password="123456">

         <readHost host="Mysql-node2" url="localhost:3340" user="root" password="123456">

         </readHost>

    </writeHost>

    <writeHost host="Mysql-node2" url="localhost:3340" user="root" password="123456">

    </writeHost>

</dataHost>

</mycat:schema>

以上是 mycat简单使用 的全部内容, 来源链接: utcz.com/z/534898.html

回到顶部