Mycat常用的分片规则

为方便查看,从《Mycat权威指南》上摘录下来,以便以后查阅

1、分片枚举

通过在配置文件中配置可能的枚举id,自己配置分片,本规则适用特定的场景,比如有些业务需要按照省份或者区县来做保存,而全国省份区县固定的,这类业务适用本条规则,配置如下:

<tableRule name="sharding-by-intfile">
<rule>
<columns>user_idcolumns>
<algorithm>hash-intalgorithm>
rule>
tableRule>
<function name="hash-int" class="org.opencloudb.route.function.PartitionByFileMap">
<property name="mapFile">partition-hash-int.txtproperty>
<property name="type">0property>
<property name="defaultNode">0property>
function>

partition-hash-int.txt 配置:
10000=0
10010=1
DEFAULT_NODE=1

上面columns标识将要分片的表字段,algorithm分片函数,
其中分片函数配置中,mapFile标识配置文件名称,type默认值为0,0表示Integer,非零表示String,所有的节点配置都是从0开始,及0代表节点1

  • defaultNode默认节点:小于0表示不设置默认节点,大于等于0表示设置默认节点
  • 默认节点的作用:枚举分片时,如果碰到不识别的枚举值,就让它路由到默认节点
  • 如果不配置默认节点(defaultNode值小于0表示不配置默认节点),碰到不识别的枚举值就会报错
    like this:can’t find datenode for sharding column:column_name val:ffffffff

2、固定分片hash算法

本条规则类似于十进制的求模运算,区别在于是二进制的操作,是取id的二进制低10位,即id二进制&1111111111

此算法的优点在于如果按照10进制取模运算,在连续插入1-10时候1-10会被分到1-10个分片,增大了插入的事务控制难度,而此算法根据二进制则可能会分到连续的分片,减少插入事务控制难度。

<tableRule name="rule1">
<rule>
<columns>user_idcolumns>
<algorithm>func1algorithm>
rule>
tableRule>
<function name="func1" class="org.opencloudb.route.function.PartitionByLong">
<property name="partitionCount">2,1property>
<property name="partitionLength">256,512property>
function>
  • 配置说明:
  • 上面columns标识将要分片的表字段,algorithm分片函数,partitionCount分片个数列表,partitionLength分片范围列表
  • 分片长度:默认为最大2^n=1024,即最大支持1024分区
  • 约束:
  • count,length两个数组的长度必须是一致的。
    (未完待续)

你可能感兴趣的:(mycat)