微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MyCAT的roul.xml的常用算法

常用的分片算法
1.配置简单取模
    可以拥有分片列为整数列表的表
    分片列mod分片基数
<tableRole name="你的表名">
    <rule>
        <columns>你的字段名></columns>
        <algorithm>你的函数名</algorithm>
     </rule>
</tableRole>
<function name="你的函数名"
    class="io.mycat.route.function.PartitionByModel"
   分片的个数
    <property name="count">2</property>
</function>
2.配置哈希取模
    可以拥有多种数据类型 比如字符串,日期等
    hash(分片列) mod 分片基数
<tableRole name="你的表名">
    <rule>
        <columns>你的字段名></columns>
        <algorithm>你的函数名</algorithm>
     </rule>
</tableRole>
<function name="你的函数名"
    class="io.mycat.route.function.PartitionByHashModel"
    <property name="count">2</property> 
</function>

3.枚举分片
    可以人为制定数据在哪个数据库
    
<tableRole name="你的表名">
    <rule>
        <columns>你的字段名></columns>
        <algorithm>你的函数名</algorithm>
     </rule>
</tableRole>
<function name="你的函数名"
    class="io.mycat.route.function.PartitionByFileMap"
    <property name="mapFile">partition-hash-int.txt</property> 
    <property name="type">0</property>
    <property name="defaultNode">0</property> 》=启用认节点
    《0不启用认节点
</function>
partition-hash-int.txt
你可能存在的值=你的库
DEFAULT_NODE=0

例如
100=0
1001=1
DEFAULT_NODE=0

字符串范围取模分片 
<function name="你的函数名"
    class="io.mycat.route.function.PartitionByPrefixPattern"
    <property name="mapFile">partition-hash-int.txt</property> 
    取模基数
    <property name="patternValue">128</property>
    取模字符长度
    <property name="prefixLength">2</property>
</function>

0-63=0
64-127=1


版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐