Mycat 是一个开源的分布式数据库系统,但是由于真正的数据库需要存储引擎,而 Mycat 并没有存 储引擎,所以并不是完全意义的分布式数据库系统。 那么 Mycat 是什么?Mycat 是数据库中间件,就是介于数据库与应用之间,进行数据处理与交互的中间服务。
MyCAT 是使用 JAVA 语言进行编写开发,使用前需要先安装 JAVA 运行环境(JRE),由于 MyCAT 中使用了 JDK7 中的一些特性,所以要求必须在 JDK7 以上的版本上运行。
Mycat 概念
DBA 或者运维人员对数据进行分片处理之后,从原有的一个库,被切分为多个分片数据库,所有的分片数据库集群构成了整个完整的数据库存储。
如上图所表示,数据被分到多个分片数据库后,应用如果需要读取数据,就要需要处理多个数据源的数据。 如果没有数据库中间件,那么应用将直接面对分片集群,数据源切换、事务处理、数据聚合都需要应用直接处 理,原本该是专注于业务的应用,将会花大量的工作来处理分片后的问题,最重要的是每个应用处理将是完全的 重复造轮子。 所以有了数据库中间件,应用只需要集中与业务处理,大量的通用的数据聚合,事务,数据源切换都由中间 件来处理,中间件的性能与处理能力将直接决定应用的读写性能,所以一款好的数据库中间件至关重要。
逻辑库(schema)
通常对实际应用来说,并不需要知道中间件的存在,业务开发人员只需要知道 数据库的概念,所以数据库中间件可以被看做是一个或多个数据库集群构成的逻辑库。
在云计算时代,数据库中间件可以以多租户的形式给一个或多个应用提供服务,每个应用访问的可能是一个 独立或者是共享的物理库,常见的如阿里云数据库服务器 RDS。
逻辑表(table)
既然有逻辑库,那么就会有逻辑表,分布式数据库中,对应用来说,读写数据的表就是逻辑表。逻辑表,可 以是数据切分后,分布在一个或多个分片库中,也可以不做数据切分,不分片,只有一个表构成。
分片规则(rule)
数据切分,一个大表被分成若干个分片表,就需要一定的规则,这样按照某种业务规则把数据分到 某个分片的规则就是分片规则,数据切分选择合适的分片规则非常重要,将极大的避免后续数据处理的难度。
一、部署JAVA环境
下载JDK到本地
上传到服务器
[root@localhost ~]# ls
jdk-8u211-linux-x64.tar.gz
[root@localhost ~]# tar -xzvf jdk-8u211-linux-x64.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/
[root@localhost local]# mv jdk1.8.0_211/ java
[root@localhost local]# vim /etc/profile
export JAVA_HOME=/usr/local/java
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
[root@localhost local]# source /etc/profile
[root@localhost local]# java -version
java version "1.8.0_211"
Java(TM) SE Runtime Environment (build 1.8.0_211-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.211-b12, mixed mode)
二、部署Mycat
[root@localhost local]# cd
[root@localhost ~]# wget http://dl.mycat.org.cn/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
[root@localhost ~]# ls
jdk-8u211-linux-x64.tar.gz Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
[root@localhost ~]# tar -xzvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz -C /usr/local/
[root@localhost ~]# ls /usr/local/mycat/
bin catlet conf lib logs version.txt
三、配置Mycat
1. 认识配置文件
MyCAT 目前主要通过配置文件的方式来定义逻辑库和相关配置
/usr/local/mycat/conf/server.xml #定义用户以及系统相关变量,如端口等。其中用户信息是前端应用程序连接 mycat 的用户信息。
/usr/local/mycat/conf/schema.xml #定义逻辑库,表、分片节点等内容。
/usr/local/mycat/conf/rule.xml #中定义分片规则。
2. 配置 server.xml
下面的用户和密码是应用程序连接到 MyCat 使用的,可以自定义配置
而其中的schemas 配置项所对应的值是逻辑数据库的名字,也可以自定义,但是这个名字需要和后面 schema.xml 文件中配置的一致。
[root@localhost ~]# vim /usr/local/mycat/conf/server.xml
<!--下面的用户和密码是应用程序连接到 MyCat 使用的.schemas 配置项所对应的值是逻辑数据库的名字,这个名字需要和后面 schema.xml 文件中配置的一致。-->
<user name="mycatdb" defaultAccount="true">
<property name="password">1</property>
<property name="schemas">mycat_db</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>
<!--下面是另一个用户,并且设置的访问 TESTED 逻辑数据库的权限是 只读
<user name="mycatuser">
<property name="password">123</property>
<property name="schemas">mycat_db</property>
<property name="readOnly">true</property>
</user>
-->
</mycat:server>
上面的配置中,假如配置了用户访问的逻辑库,那么必须在 schema.xml
文件中也配置这个逻辑库,否则报错,启动 mycat 失败
3. 配置schema.xml
以下是配置文件中的每个部分的配置块儿
[root@localhost ~]# vim /usr/local/mycat/conf/schema.xml
3.1 逻辑库和分表设置
<schema name="mycat_db" // 逻辑库名称,与server.xml的一致
checkSQLschema="false" // 不检查
sqlMaxLimit="100" // 最大连接数
dataNode="dn1"> // 数据节点名称
<!--这里定义的是分表的信息-->
</schema>
3.2 数据节点
<dataNode name="dn1" // 此数据节点的名称
dataHost="localhost1" // 主机组
database="mycat_test" /> // 真实的数据库名称
3.3 主机组
<dataHost name="localhost1" // 主机组
maxCon="1000" minCon="10" // 连接
balance="0" // 负载均衡
writeType="0" // 写模式配置
dbType="mysql" dbDriver="native" // 数据库配置
switchType="1" slaveThreshold="100">
<!--这里可以配置关于这个主机组的成员信息,和针对这些主机的健康检查语句-->
</dataHost>
balance 属性
负载均衡类型,目前的取值有 3 种:
1. balance="0", 不开启读写分离机制,所有读操作都发送到当前可用的 writeHost 上。
2. balance="1", 全部的 readHost 与 stand by writeHost 参与 select 语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且 M1 与 M2
互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡。
4. balance="2", 所有读操作都随机的在 writeHost、readhost 上分发。
5. balance="3", 所有读请求随机的分发到 wiriterHost 对应的 readhost 执行,writerHost 不负担读压力,注意 balance=3 只在 1.4 及其以后版本有,1.3 没有。
writeType 属性
负载均衡类型,目前的取值有 3 种:
1. writeType="0", 所有写操作发送到配置的第一个 writeHost,第一个挂了切到还生存的第二个writeHost,重新启动后已切换后的为准.
2. writeType="1",所有写操作都随机的发送到配置的 writeHost,1.5 以后废弃不推荐。
3.4 健康检查
<heartbeat>select user()</heartbeat>
3.5 读写配置
<writeHost host="hostM1" url="192.168.19.176:3306" user="root" password="1">
<!-- can have multi read hosts -->
<readHost host="hostS2" url="192.168.19.177:3306" user="root" password="1" />
</writeHost>
3.6 以下是组合为完整的配置文件,适用于一主一从的架构
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<schema name="mycat_db"
checkSQLschema="false"
sqlMaxLimit="100"
dataNode="dn1">
<!--这里定义的是分库分表的信息-->
</schema>
<dataNode name="dn1"
dataHost="localhost1" database="mycat_test" />
<dataHost name="localhost1"
maxCon="1000" minCon="10"
balance="0"
writeType="0"
dbType="mysql" dbDriver="native"
switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM1" url="192.168.19.176:3306"
user="root" password="1">
<!-- can have multi read hosts -->
<readHost host="hostS2" url="192.168.19.177:3306"
user="root" password="1" />
</writeHost>
</dataHost>
</mycat:schema>
4. 日志级别
[root@localhost ~] vim /usr/local/mycat/conf/rule.xml
<!--设置日志级别为 debug , 默认是 info-->
<asyncRoot level="debug" includeLocation="true">
5. 启动 mycat
[root@localhost ~]# /usr/local/mycat/bin/mycat start
Starting Mycat-server...
支持以下参数
start | restart |stop | status
四、在真实的 master 数据库上给用户授权
mysql> grant all on mycat_test.* to root@'%' identified by '1';
mysql> flush privileges;
五、测试
在 mycat 的机器上测试用户权限有效性
测试是否能正常登录上 主服务器
mysql -uroot -p'123' -h192.168.19.176
继续测试是否能登录上从服务器
mysql -uroot -p'123' -h192.168.19.177
通过客户端进行测试是否能登录到 mycat 上
192.168.19.178 是 mycat 的主机地址
注意端口号是 8066
[root@mysqlclient ~]# mysql -umycatdb -p1 -h192.168.19.178 -P8066
MySQL [(none)]> show databases;
+----------+
| DATABASE |
+----------+
| mycat_db |
+----------+
1 row in set (0.00 sec)
继续测试读写分离策略
使用 mysql
客户端工具使用 mycat
的账户和密码登录 mycat
,
之后执行 select
语句。
之后查询 mycat
主机上 mycat
安装目录下的 logs/mycat.log
日志。
在日志重搜索查询的语句或者查询 从库的 ip 地址,应该能搜索到