当前位置: 首页 > article >正文

mycat --分片规则--

文章目录

  • MyCat分片规则详解
    • 1. rule1 (基于id的func1算法)
    • 2. sharding-by-date (按日期分片)
    • 3. rule2 (基于user_id的func1算法)
    • 4. sharding-by-intfile (基于枚举值分片)
    • 5. auto-sharding-long (长整型范围分片)
    • 6. mod-long (取模分片)
    • 7. sharding-by-murmur (MurmurHash分片)
    • 8. crc32slot (CRC32分片)
    • 9. sharding-by-month (按月分片)
    • 10. latest-month-calldate (最近月份分片)
    • 11. auto-sharding-rang-mod (范围+取模分片)
    • 12. jch (Jump Consistent Hash分片)
    • 总结对比表

MyCat分片规则详解

下面我将详细解释您列出的这些MyCat分片规则的工作原理和适用场景:

1. rule1 (基于id的func1算法)

<tableRule name="rule1"><rule><columns>id</columns><algorithm>func1</algorithm></rule>
</tableRule>
  • 规则:使用自定义函数func1对id列进行分片
  • 特点:需要查看func1的具体实现才能确定分片逻辑
  • 适用场景:需要特殊分片逻辑的业务场景

2. sharding-by-date (按日期分片)

<tableRule name="sharding-by-date"><rule><columns>createTime</columns><algorithm>partbyday</algorithm></rule>
</tableRule>
  • 规则:按createTime字段的日期(天)进行分片
  • 特点
    • 每天的数据存储在同一分片
    • 便于按时间范围查询
  • 适用场景:日志、订单等时间序列数据

3. rule2 (基于user_id的func1算法)

<tableRule name="rule2"><rule><columns>user_id</columns><algorithm>func1</algorithm></rule>
</tableRule>
  • 规则:使用与rule1相同的func1算法,但针对user_id列
  • 特点:同一用户的数据会分配到固定分片
  • 适用场景:需要按用户ID分片的业务

4. sharding-by-intfile (基于枚举值分片)

<tableRule name="sharding-by-intfile"><rule><columns>sharding_id</columns><algorithm>hash-int</algorithm></rule>
</tableRule>
  • 规则:根据sharding_id的枚举值映射到不同分片
  • 特点
    • 需要配置分片映射文件
    • 分片规则明确且固定
  • 适用场景:数据有明确分类的场景,如按地区、业务线分片

5. auto-sharding-long (长整型范围分片)

<tableRule name="auto-sharding-long"><rule><columns>id</columns><algorithm>rang-long</algorithm></rule>
</tableRule>
  • 规则:按照id的数值范围进行分片
  • 特点
    • 需要预先定义范围规则
    • 范围查询效率高
  • 适用场景:ID是连续增长的数字,如自增主键

6. mod-long (取模分片)

<tableRule name="mod-long"><rule><columns>id</columns><algorithm>mod-long</algorithm></rule>
</tableRule>
  • 规则:对id值进行取模运算,根据结果分配到不同分片
  • 特点
    • 数据分布均匀
    • 扩容时需要数据迁移
  • 适用场景:需要均匀分布数据的场景

7. sharding-by-murmur (MurmurHash分片)

<tableRule name="sharding-by-murmur"><rule><columns>id</columns><algorithm>murmur</algorithm></rule>
</tableRule>
  • 规则:使用MurmurHash算法对id进行哈希分片
  • 特点
    • 哈希分布均匀
    • 比传统哈希算法性能更好
  • 适用场景:需要均匀分布且高效的哈希分片

8. crc32slot (CRC32分片)

<tableRule name="crc32slot"><rule><columns>id</columns><algorithm>crc32slot</algorithm></rule>
</tableRule>
  • 规则:使用CRC32算法对id进行哈希分片
  • 特点
    • 计算速度快
    • 分布相对均匀
  • 适用场景:需要快速哈希计算的场景

9. sharding-by-month (按月分片)

<tableRule name="sharding-by-month"><rule><columns>create_time</columns><algorithm>partbymonth</algorithm></rule>
</tableRule>
  • 规则:按create_time字段的月份进行分片
  • 特点
    • 每月数据存储在同一分片
    • 便于按月归档
  • 适用场景:需要按月统计或归档的数据

10. latest-month-calldate (最近月份分片)

<tableRule name="latest-month-calldate"><rule><columns>calldate</columns><algorithm>latestMonth</algorithm></rule>
</tableRule>
  • 规则:最近一个月的数据单独分片,历史数据按其他规则分片
  • 特点
    • 热点数据单独处理
    • 冷热数据分离
  • 适用场景:需要特别处理最近数据的业务,如通话记录

11. auto-sharding-rang-mod (范围+取模分片)

<tableRule name="auto-sharding-rang-mod"><rule><columns>id</columns><algorithm>rang-mod</algorithm></rule>
</tableRule>
  • 规则:先按范围分片,范围内再按取模分片
  • 特点
    • 结合范围和哈希优点
    • 便于扩容
  • 适用场景:大数据量且需要灵活扩容的场景

12. jch (Jump Consistent Hash分片)

<tableRule name="jch"><rule><columns>id</columns><algorithm>jump-consistent-hash</algorithm></rule>
</tableRule>
  • 规则:使用Jump Consistent Hash算法进行分片
  • 特点
    • 扩容时数据迁移量少
    • 不需要维护哈希环
  • 适用场景:需要频繁扩容缩容的场景

总结对比表

分片规则算法类型特点适用场景
rule1自定义灵活特殊业务需求
sharding-by-date日期按天分片时间序列数据
rule2自定义按用户分片用户数据隔离
sharding-by-intfile枚举固定映射分类明确数据
auto-sharding-long范围范围查询高效连续ID
mod-long取模均匀分布均匀分布需求
sharding-by-murmur哈希高性能哈希高效哈希需求
crc32slot哈希快速计算快速哈希需求
sharding-by-month日期按月分片月度统计
latest-month-calldate冷热热点分离近期数据处理
auto-sharding-rang-mod混合范围+哈希大数据量灵活扩容
jch一致性哈希扩容友好频繁扩容场景

相关文章:

mycat --分片规则--

文章目录 MyCat分片规则详解1. rule1 (基于id的func1算法)2. sharding-by-date (按日期分片)3. rule2 (基于user_id的func1算法)4. sharding-by-intfile (基于枚举值分片)5. auto-sharding-long (长整型范围分片)6. mod-long (取模分片)7. sharding-by-murmur (MurmurHash分片)…...

wireshark抓包分析数据怎么看 wireshark使用教程_wireshark怎么看

Wireshark与Sniff Master&#xff1a;网络抓包工具使用指南 网络抓包分析是开发测试和网络故障排查中不可或缺的技能。在众多抓包工具中&#xff0c;Wireshark无疑是最流行且功能强大的选择&#xff0c;而Sniff Master作为后起之秀&#xff0c;也因其简洁高效的特点受到许多专…...

Outlook客户端无法连接到服务器,添加账户显示“无网络连接,请检查你的网络设置,然后重试。[2603]”

1、先切换一下到手机热点或者其他网络&#xff0c;判断是不是现在所连接的网络的问题。如果有VPN代理软件&#xff0c;网银软件&#xff0c;加密软件在后台运行&#xff0c;麻烦退出一下。 2、打开电脑上的 控制面板——网络和Internet——Internet选项——高级——先点击还原…...

LlamaIndex实现RAG增强:融合检索(Fusion Retrieval)与混合检索(Hybrid Search)

&#x1f9e0; 向所有学习者致敬&#xff01; “学习不是装满一桶水&#xff0c;而是点燃一把火。” —— 叶芝 我的博客主页&#xff1a; https://lizheng.blog.csdn.net &#x1f310; 欢迎点击加入AI人工智能社区&#xff01; &#x1f680; 让我们一起努力&#xff0c;共创…...

递归(实践版)

这篇博客我不会写太多细节,我只做一件事,那就是教你如何写好一个递归. 二叉树的后序遍历 public void dfs(TreeNode root){if(rootnull)return;dfs(root.left);dfs(root.right);System.out.println(root.val); } 归并排序 public void merge(int[] nums,int left,int right)…...

JavaScript instanceof 运算符全解析

JavaScript instanceof 运算符全解析 核心语义: 判断一个对象(object)是否属于某个构造函数(constructor)或类的实例,基于原型链(prototype chain)实现类型检测。 一、JavaScript 中的基础用法 1. 语法结构 object instanceof constructor 返回值:布尔值(true/fal…...

蓝桥杯冲刺:一维前缀和

系列文章目录 蓝桥杯系列&#xff1a;一维前缀和 文章目录 系列文章目录前言一、暴力的写法&#xff1a;二、一维前缀和的模板&#xff1a; 具体实现&#xff1a; 三、具体例题&#xff1a;求和 1.题目参考&#xff1a;2.以下是具体代码实现&#xff1a; 总结 前言 上次我介绍…...

Ubuntu24.04-中文输入法的切换

Ubuntu24.04在安装后自带中文全拼输入法。。 根据官方的说明&#xff0c;需使用 shift super 空格 切换输入法&#xff0c;但在之前使用windows或者ubuntu的早些版本&#xff0c;多使用 Ctrl 空格 的方式切换输入法&#xff0c;本文就介绍如何进行输入法快捷键切换的配置&a…...

技术回顾day3

1.获取文件信息、获取视频信息 走的都是同一个方法&#xff1a;baseController里面的getFile。 在getFile方法里面进行判断文件的类型&#xff0c;判断是不是m3u8类型或者ts类型做一些额外的处理。 获取信息底层就是读取文件&#xff0c;然后写入response的OutputStream ou…...

埃文科技企业AI大模型一体机——昇腾体系+DeepSeek+RAG一站式解决方案

面对企业级市场海量数据资产与复杂业务场景深度耦合的刚需&#xff0c;埃文科技重磅推出基于华为昇腾算力DeepSeek大模型的企业一体机产品&#xff0c;提供DeepSeek多版本大模型一体机选择&#xff0c;为企业提供本地昇腾算力DeepSeek大模型RAG知识库的一体化解决方案&#xff…...

SAP-ABAP:ABAP `LEAVE LIST-PROCESSING` 深度解析

ABAP LEAVE LIST-PROCESSING 深度解析 核心机制 模式切换(Dialog → List) 中断屏幕流 强制终止当前Dialog程序的PBO/PAI处理,脱离屏幕序列控制(如事务码SE38执行的程序)。触发报表事件 激活类报表程序的事件链:INITIALIZATION → AT SELECTION-SCREEN → START-OF-SEL…...

JavaWeb开发基础知识-Servlet终极入门指南(曼波萌新版)

(✪▽✪)曼波~~~~&#xff01;欢迎来到Servlet新手村&#xff01;准备好开启Web开发的奇妙冒险了吗&#xff1f;让曼波用最有趣的方式带你飞~ &#x1f680; &#x1f308; 第①章 什么是Servlet&#xff1f; // 本质就是一个Java类&#xff01; public class HelloServlet e…...

游戏引擎学习第198天

回顾并为今天的内容设定 今天我们有一些代码需要处理。昨天我们进行了一些调试界面的整合工作&#xff0c;之前我们做了一些临时的、粗糙的操作&#xff0c;将一些东西读进来并放到调试界面中。今天&#xff0c;我们并不打算进行大规模的工作&#xff0c;更多的是对之前的代码…...

Walrus 基金会启动 RFP 计划,推动生态发展

Walrus 基金会正式推出 Walrus RFP 提案申请计划&#xff0c;为推动和支持 Walrus 生态的项目提供资金支持。该计划旨在助力构建符合协议使命的解决方案&#xff0c;解锁去中心化和可编程存储的潜力。 无论项目是开发新工具、探索集成&#xff0c;还是提出创新用例&#xff0c…...

智能配电箱:重塑未来电力管理的核心枢纽

哇塞&#xff01;智能配电箱可是未来电力管理的超级核心枢纽呀&#xff0c;正以超燃的态势引领着电力行业迈向智能化变革的新征程呢&#xff01;它在众多方面所展现出的独特优势和那广阔无垠的应用前景&#xff0c;简直太令人激动啦&#xff01;下面就来瞧瞧智能配电箱在重塑未…...

透过 /proc 看见内核:Linux 虚拟文件系统与 systemd 初始化初探

当我们在终端中输入 ps、top、cat /proc/cpuinfo 等命令时&#xff0c;是否思考过这些信息来自哪里&#xff1f;为什么无需启动任何守护进程&#xff0c;就能实时读取系统负载、内存占用&#xff0c;甚至内核版本&#xff1f;这一切的答案&#xff0c;都藏在 Linux 系统中的一个…...

深入理解DRAM刷新机制:异步刷新为何无需扣除刷新时间?

引言 在计算机组成原理和存储器系统的学习中&#xff0c;DRAM&#xff08;动态随机存取存储器&#xff09;的刷新机制是一个关键问题。许多同学在学习时会遇到一个疑问&#xff1a; “为什么异步刷新的刷新信号周期可以直接用 总时间/行数 计算&#xff08;如 2ms/3262.5μs&a…...

用DrissionPage升级维基百科爬虫:更简洁高效的数据抓取方案

一、原方案痛点分析 原代码使用urllibBeautifulSoup组合存在以下问题&#xff1a; 动态内容缺失&#xff1a;无法获取JavaScript渲染后的页面内容 反爬能力弱&#xff1a;基础请求头易被识别为爬虫 代码冗余&#xff1a;需要单独处理SSL证书验证 扩展性差&#xff1a;难以应…...

C++STL——容器-vector(含部分模拟实现,即地层实现原理)(含迭代器失效问题)

目录 容器——vector 1.构造 模拟实现 2.迭代器 模拟实现&#xff1a; ​编辑 3.容量 模拟实现&#xff1a; 4.元素的访问 模拟实现 5.元素的增删查改 迭代器失效问题&#xff1a; 思考问题 【注】&#xff1a;这里的模拟实现所写的参数以及返回值&#xff0c;都是…...

严重BUG修复及部分体验问题优化

随着Deepseek APIPython 测试用例一键生成与导出 V1.0.6的试用不断深入&#xff0c;会出现程序异常崩溃的问题。经群友定位&#xff0c;紧急修复了bug&#xff0c;并适当优化部分体验性问题。针对生成的测试用例xlsx文档&#xff0c;可以再次选中该xlsx给大模型进行推理生成新的…...

黑马 C++ 学习笔记

课程链接&#xff1a;黑马 C 文章目录 C 基础语法指针空指针和野指针 const 修饰指针 C 核心编程程序的内存分区模型程序运行前程序运行后new 操作符 引用引用的基本使用引用的注意事项引用作函数参数引用作函数返回值引用的本质常量引用 函数的提高函数默认参数函数默认参数函…...

Elasticsearch 证书问题解决

报错信息 javax.net.ssl.SSLHandshakeException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested targetat org.elasticsearch.client.RestClient. extractAndWrapCause(R…...

I²C总线高级特性与故障处理分析

IC总线高级特性与故障处理深度分析 目录 1. IC基础回顾 1.1 IC通信基本原理1.2 IC总线时序与协议1.3 寻址方式与读写操作 2. IC高级特性 2.1 多主机模式2.2 时钟同步与伸展2.3 高速模式与Fast-mode Plus2.4 10位寻址扩展 3. IC总线故障与锁死 3.1 断电锁死原理3.2 总线挂起与…...

山东大学《多核平台下的并行计算》实验笔记

每年的题目都不一样,学弟学妹参考参考就行。 一、搭建linux环境 主播用的ssh+虚拟机,目前用着最顺手的 二、安装并行编程软件 MPI(Message Passing Interface),由其字面意思也可些许看出,是一个信息传递接口。可以理解为是一种独立于语言的信息传递标准。而OpenMPI和MP…...

2023年CIE SCI1区TOP:序列融合麻雀搜索算法ISSA,深度解析+性能实测

目录 1.摘要2.麻雀搜索算法SSA原理3.改进策略3.结果展示4.参考文献5.代码获取 1.摘要 麻雀搜索算法&#xff08;SSA&#xff09;是一种基于麻雀觅食和防捕行为的群体智能算法。然而&#xff0c;基本SSA在迭代过程中&#xff0c;种群多样性逐渐降低&#xff0c;容易陷入局部最优…...

elasticsearch 如果按照日期进行筛选

如果你需要按照日期进行筛选&#xff0c;你可以使用 Elasticsearch 的范围查询来实现。以下是一个示例代码&#xff0c;演示如何在 Java 中进行日期范围查询&#xff1a; import org.apache.http.HttpHost; import org.elasticsearch.client.RestClient; import org.elasticse…...

SpringBoot条件装配注解

SpringBoot条件装配注解 Spring Boot 提供了一系列条件装配注解&#xff0c;用于控制 Bean 的创建和装配过程。以下是一些常用的条件装配注解及其详细介绍&#xff1a; ConditionalOnClass 作用&#xff1a;当类路径中存在指定的类时&#xff0c;才会创建该 Bean。 示例&#…...

配置晟腾910b的PyTorch torch_npu环境

1.【新教程】华为昇腾NPU的pytorch环境搭建 - Lukea - 博客园 1、新建conda环境。 conda create -n pytorch python3.102、在新建好的conda环境中&#xff0c;安装基础的依赖。 pip install attrs cython numpy1.24.0 decorator sympy cffi pyyaml pathlib2 psutil protobuf…...

算法刷题记录——LeetCode篇(3.10) [第291~300题](持续更新)

更新时间&#xff1a;2025-04-02 算法题解目录汇总&#xff1a;算法刷题记录——题解目录汇总技术博客总目录&#xff1a;计算机技术系列博客——目录页 优先整理热门100及面试150&#xff0c;不定期持续更新&#xff0c;欢迎关注&#xff01; 295. 数据流的中位数 中位数是…...

conda 激活环境vscode的Bash窗口

多份conda环境注意事项&#xff0c;当时安装了两个conda环境&#xff0c;miniconda和conda&#xff0c;导致环境总是冲突矛盾。初始化时需要更加注意。 $ C:/Users/a_hal/miniconda3/Scripts/conda.exe init bash能够显示用哪里的conda环境命令执行。 然后直接conda activate…...