Java中支持分库分表的框架/组件/中间件简介

文章目录

  • [1 sharding-jdbc](#1 sharding-jdbc)
  • [2 TSharding](#2 TSharding)
  • [3 Atlas](#3 Atlas)
  • [4 Cobar](#4 Cobar)
  • [5 MyCAT](#5 MyCAT)
  • [6 TDDL](#6 TDDL)
  • [7 Vitess](#7 Vitess)

列举一些比较常见的,简单介绍一下:

sharding-jdbc(当当)

TSharding(蘑菇街)

Atlas(奇虎360)

Cobar(阿里巴巴)

MyCAT(基于Cobar)

TDDL(淘宝)

Vitess(谷歌)

1 sharding-jdbc

首先,第一个,可能也是最常见最常用的,Sharding-JDBC,这个是最早的名字,现在已经发展成为ShardingSphere,生态,详细介绍及使用方法请移步:Sharding-JDBC介绍及实践

2 TSharding

用于蘑菇街交易平台的分库分表组件,很少的资源投入即可开发完成,支持交易订单表的Sharding需求,分库又分表,支持数据源路由,支持事务,支持结果集合并,支持读写分离。

3 Atlas

基于MySQL-Proxy上二次开发的,主要支持两个特性:分表和读写分离,但是分表的话只支持单库多表,即事实上是不支持分布式分表的,所有分表都在同一个库中。

4 Cobar

阿里的关系型数据的分布式处理系统,以proxy的形式位于前台应用和实际数据库之间,对前台的开放的接口是mysql通信协议。将前台SQL语句变更并按照数据分布规则转发到合适的后台数据分库,再合并返回结果,模拟单库下的数据库行为。

5 MyCAT

实现了 MySQL 协议 的服务器,前端用户可以把它看作是一个数据库代理,用 MySQL 客户端工具和命令行访问, 而其后端可以用 MySQL 原生协议与多个 MySQL 服务器通信,也可以用 JDBC 协议与大多数 主流数据库服务器通信,其核心功能是分库分表。配合数据库的主从模式还可实现读写分离。

6 TDDL

主要解决了分库分表对应用的透明化以及异构数据库之间的数据复制,它是一个基于集中式配置的 jdbc datasource实现,具有主备,读写分离,动态数据库配置等功能。

7 Vitess

是Youtube开源的数据库扩展及高可用方案,已经用于生产环境,功能强大,但是构架复杂,部署及运维成本较高。

相关推荐
MobiCetus6 分钟前
C++多线程编程简介
linux·服务器·开发语言·c++·人工智能·python·ubuntu
qq_459238496 分钟前
java八股文之JVM
java·开发语言·jvm
珹洺16 分钟前
Java-servlet(九)前端会话,会话管理与Cookie和HttpSession全解析
android·java·服务器·开发语言·前端·数据库·servlet
命运之光23 分钟前
Go File容器化部署方案:本地快速搭建与无公网IP远程传输文件指南
开发语言·tcp/ip·golang·内网穿透
mit6.82424 分钟前
[OS_4] 数学视角 | 多状态 | 模型检查器 | 程序验证(math)
开发语言·算法·系统架构
AC-PEACE24 分钟前
JS 防抖与节流
开发语言·前端·javascript
数据知道25 分钟前
【Lua】一文快速掌握 Lua 语言指令(Lua 备忘清单)
开发语言·junit·lua
俄城杜小帅28 分钟前
pytorch+maskRcnn框架训练自己的模型以及模型导出ONXX格式供C++部署推理
开发语言·c++·目标检测
一只鱼^_36 分钟前
科软25机试
开发语言·数据结构·c++·算法·leetcode·面试·排序算法
2301_7644413338 分钟前
资本运营:基于Python实现的资本运作模拟
开发语言·python·数学建模·职场和发展·创业创新