最近在看 mycat ,官网: http://www.mycat.io/ 上面就有 PDF 的教程下载。但是对于我这个初学者来讲,搭建环境的时候还是有点晕,下面从一个简单的例子来讲解相关配置。我用的是 linux 版本的,在解压后的目录记作:${MYCAT},在 ${MYCAT}/conf 目录下有几个关键的配置文件。
1. server.xml
主要用来配置 mycat 这个服务器的一些配置。程序员开发时,应该只关注一个数据库连接,但是分库分表时,数据是存在不同的物理机的 mysql 里的。 这个文件的其实配置的就是一个数据源,这个数据源可以通过 mycat 去按需连接到不同的物理机的 mysql 去获取数据。
<!-- 连接 mycat 的端口 -->
<property name="serverPort">8066</property>
<!-- 是否采用zookeeper协调切换 -->
<property name="useZKSwitch">false</property>
</system>
<!-- 连接 mycat 的用户和密码 -->
<user name="root">
<property name="password">123456</property>
<property name="schemas">TESTDB</property><!-- 修改 schemas 内的文本来控制用户可访问的 schema,同时访问多个 schema 的话使用 , 隔开 -->
<property name="readOnly">false</property>
</user>
2. schema.xml
主要用来配置 mycat 的逻辑库及其下面的表。逻辑库可以理解为 mysql 中数据库。
<schema name="TESTDB" checkSQLschema="true" sqlMaxLimit="100">
<!-- auto sharding by id (long) -->
<table name="student" primaryKey="id" autoIncrement="true" dataNode="dn1,dn2" rule="auto-sharding-long" />
</schema>
<dataNode name="dn1" dataHost="host108" database="stu108" />
<dataNode name="dn2" dataHost="host109" database="stu109" />
<dataHost name="host108" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select 1</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM1" url="192.168.8.108:3306" user="root" password="111111">
</writeHost>
</dataHost>
<dataHost name="host109" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
2.1
属性值:
checkSQLschema 当该值设置为 true 时,如果我们执行语句**select * from TESTDB.travelrecord;**则 MyCat 会把语句修改为**select * from travelrecord;**。即把表示 schema 的字符去掉,避免发送到后端数据库执行时报**(ERROR1146 (42S02): Table ‘testdb.travelrecord’ doesn’t exist)。 **不过,即使设置该值为 true ,如果语句所带的是并非是 schema 指定的名字,例如: **select * from db1.travelrecord;** 那么 MyCat 并不会删除 db1 这个字段,如果没有定义该库的话则会报错,所以在提供 SQL语句的最好是不带这个字段 。
sqlMaxLimit 当该值设置为某个数值时。每条执行的 SQL 语句,如果没有加上 limit 语句, MyCat 也会自动的加上所对应的值。例如设置值为 100,执行**select * from TESTDB.travelrecord;**的效果为和执行**select * from TESTDB.travelrecord limit 100;**相同。
2.2 它又依赖了一个 "rang-long" 的算法。这个算法是根据 autopartition-long.txt 中的定义来决定数据存在哪个 mysql 里。 2.3 2.4 假设 mycat 服务部署在 192.168.8.188 上面,那么通过上面的配置,我们可以通过 jdbc:mysql://192.168.8.188:8066/TESTDB 用户/密码: root/123456 (server.xml 中 3. rule.xml 这个文件中配置的是各种各样的规则,默认已经有挺多的了。这些规则用于 手机扫一扫 移动阅读更方便 你可能感兴趣的文章 配置的是逻辑库下有什么表。其中 dataNode="dn1,dn2" 表示这个表的数据会存放在 dn1 和 dn2 上。rule 属性用的是 rule.xml 中的某个值。上面配置了“auto-sharding-long”, 看一下这个在 rule.xml 中的定义:
的配置),这个表的数据其实是根据 rule 的配置规则,存入到 192.168.8.108:3306 中的 stu108 数据库和 192.168.8.109:3306 中的 stu109 数据库。
中 rule 属性。mycat 根据指定的规则把数据存入到实际的物理库中。这个文件基本不用改。注意:如果使用的是 mod-long 这个规则的话,需要更改 count 这个属性的值,数量需要同 schema.xml 中 配置的