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

海量数据存储实现方案设计1-mycat版

目的

这里使用mycat为例子说明方案设计思路(仅个人学习、思考笔记)。主要尝试解决海量数据存储、动态不停机扩容问题,不再受限于单库、单表、单机等。

mycat简述

mycat 主要以中间件代理的方式,不侵入工程代码来实现分库分表,需要单独部署,应用端查询数据库的过程多了一层转发处理。

mycat应用场景-分库分表

普通的分库分表实现

mycat应用场景-多租户物理隔离

实现多租户物理库的隔离,一个租户分配一个节点库或多个节点库实例,但应用程序只连接 mycat,从而不改造程序本身,实现多租户化。

前提条件

Mycat在更新配置文件后,可以通过不重启服务的方式使配置生效‌,从而保证已连接的应用不受影响,类似nginx reload来刷新使配置生效。

具体操作

  • 租户创建时,节点资源申请、审核。
  • 审核通过后,自动创建对应的节点实例,并添加节点路由配置到mycat并刷新其配置文件。
  • 新租户的数据库实例路由生效,达到物理库隔离。

mycat应用场景-海量数据的不停机扩容

新增节点服务器,可以按年、月等时间分区路由到新的节点服务器,来达到扩容的目的;或者回收节点服务器亦可。

针对新增的节点服务器路由配置,mycat可以类似nginx reload等不停机来刷新。跟上面大体类似的步骤。

或者使用doris等其他组件的话,应该也可以类似不停机更新来达到分区扩容目的。

http://www.lryc.cn/news/513988.html

相关文章:

  • Elasticsearch检索之三:官方推荐方案search_after检索实现(golang)
  • hot100_238. 除自身以外数组的乘积
  • 软件测试基础详解
  • MySQL 备份方案设计之准备事项
  • 《计算机网络A》单选题-复习题库解析-最终
  • 向 SwiftUI 视图注入 managedObjectContext 环境变量导致 Xcode 预览(Preview)崩溃的解决
  • Ruby 数据类型
  • 复合机器人正以其高效、精准、灵活的特点,逐渐在汽车装配线上崭露头角
  • Docker + JMeter + InfluxDB + Grafana搭建压测可视化实时监控
  • leetcode 2658. 网格图中鱼的最大数目
  • Java 集合 Collection、List、Set
  • 报错:nginx [emerg] open() etcnginxnginx.conf failed (2 No such file or directory)
  • 基于AI的运维资源调度:效率与智能的双重提升
  • 自动化办公 | 根据成绩进行自动评级
  • 纯血鸿蒙ArkUI线性布局详解
  • 小程序组件 —— 22 组件案例 - 轮播区域绘制
  • 如何判断一个学术论文是否具有真正的科研价值?ChatGPT如何提供帮助?
  • 【置顶】测试学习笔记整理
  • 新浪微博Java开发面试题及参考答案
  • 【SQL Server】教材数据库(1)
  • Windows系统下载、部署Node.js与npm环境的方法
  • SQL 总结
  • 设计一个基于Spring Boot开发的电商网站,部署在阿里云上
  • Java jni调用nnom rnn-denoise 降噪
  • C++软件设计模式之状态模式
  • Microsoft Visual Studio中的/MT, /MTd,/MD,/MDd分别是什么意思?
  • 谷粒商城项目125-spring整合high-level-client
  • 日期时间选择(设置禁用状态)
  • 基于SpringBoot的题库管理系统的设计与实现(源码+SQL+LW+部署讲解)
  • 钉钉h5微应用安卓报错error29 ios报错error3 加上报错52013,签名校验失败 (前端)