Sharding-JDBC分库分表 概述 [文档]

news/2023/9/27 6:44:32

Sharding-Sphere概述

在介绍Sharding-JDBC之前,我们需要先说明下Sharding-Sphere。
Sharding-Sphere是一套开源的分布式数据库中间件解决方案组成的生态圈,它由Sharding-JDBC、Sharding-Proxy和Sharding-Sidecar(计划中)这3款相互独立的产品组成。他们均提供标准化的数据分片、分布式事务和数据库治理功能,可适用于如Java同构、异构语言、容器、云原生等各种多样化的应用场景。

 

Sharding-JDBC概述

Sharding-JDBC 是一个开源的分布式数据库中间件,它无需额外部署和依赖,旧代码迁移成本几乎为零。Sharding-JDBC 作为面向开发的微服务云原生基础类库,完整地实现了分库分表、读写分离和分布式主键功能,并初步实现柔性事务

它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。

(1)适用于任何基于Java的ORM框架,如:JPA, Hibernate, Mybatis, Spring JDBC Template或直接使用JDBC。
(2)基于任何第三方的数据库连接池,如:DBCP, C3P0, BoneCP, Druid, HikariCP等。
(3)支持任意实现JDBC规范的数据库。目前支持MySQL,Oracle,SQLServer和PostgreSQL。

Sharding-Proxy概述

Sharding-Proxy定位为透明化的数据库代理端,提供封装了数据库二进制协议的服务端版本,用于完成对异构语言的支持。 目前先提供MySQL版本,它可以使用任何兼容MySQL协议的访问客户端(如:MySQL Command Client, MySQL Workbench等)操作数据,对DBA更加友好。

 

常用的Client模式和Proxy模式概述

Client模式属于客户端直连方案。此方案的优势在于轻便、兼容性、性能以及对DBA影响小。
Proxy模式属于中间层方案,在应用程序和MySQL之间搭建一层Proxy。中间层介于应用程序与数据库间,需要做一次转发,而基于JDBC协议并无额外转发,直接由应用程序连接数据库,性能上有些许优势。这里并非说明中间层一定不如客户端直连,除了性能,需要考虑的因素还有很多,中间层更便于实现监控、数据迁移、连接管理等功能。
Client模式:阿里的TDDL、当当网的sharding-jdbc、Cobar-Client
Proxy模式:阿里的cobar、民间组织的MyCAT、MySQL-Proxy、Amoeba for MySQL、Atlas(360)、MaxScale

 


https://dhexx.cn/news/show-18645.html

相关文章

什么是垂直分库分表,水平分库分表

垂直分片 按照业务拆分的方式称为垂直分片,又称为纵向拆分,它的核心理念是专库专用。 在拆分之前,一个数据库由多个数据表构成,每个表对应着不同的业务。而拆分之后,则是按照业务将表进行归类,分布到不同的…

函数、递归 与 闭包(执行环境、变量对象 与 作用域链)

函数表达式 1、JavaScript中定义函数有2钟方法: 1-1.函数声明: function funcName(arg1,arg2,arg3){//函数体 } ①name属性:可读取函数名。非标准,浏览器支持:FF、Chrome、safari、Opera。    ②函数声明提升:指执…

linux环境nutch的配置,Nutch 1.3 在Ubuntu上的简单配置

因为Nutch 1.3跟以前比改了不少东西,所以1.2中的有些配置已经不在适用了首先我的机器用的是Ubuntu 10.04,挺老的版本了,因为有它的光盘,一直没有升级当然是先下载nutch的包了,用的人人的镜像http://labs.renren.com/apache-mirror…

Sharding-JDBC(版本3.0) 入门demo-1,纯java 代码

先创建ds_0,ds_1两个数据库,并同时在两个数据库中创建表t_order_0,t_order_1两个表 CREATE TABLE t_order_0 (order_id int(11) DEFAULT NULL,user_id int(11) DEFAULT NULL,status varchar(50) DEFAULT NULL ) ENGINEInnoDB DEFAULT CHARSETutf8; 1 新建maven项目…

Mac下用SHA-1校验文件

在Terminal中输入 openssl sha1 [filename] 效果如下 转载于:https://www.cnblogs.com/alex4814/archive/2013/05/10/3070511.html

amd cpu跑linux64,Oracle 11.2.0.1在AMD CPU 64位硬件,32位操作系统下的BUG 8670579

bug 8670579硬件信息:CPU:AMD X6在执行dbca的时候也报错如下:[Oracleyorkshi ~]$ dbca## An unexpected error has been detected byHotSpot Virtual Machine:## SIGSEGV (0xb) at pc0x9e2ea35e, pid13501, tid3086244048## Java VM: Java HotSpot(TM) S…

Sharding-JDBC(版本3.0) 分库分表入门demo-3 springboot+mybatis+druid+分布式主键(可选)+绑定表+默认数据源等

先创建好数据库ds_0,ds_1 并分别在两个数据库中创建表news,order_info_0,order_info_1,order_item_0,order_item_1 其中 news表用于默认数据源配置的测试 order_info和order_item为分库分表和绑定表测试 CREATE TABLE…

在MVC3中抛出错误页--HttpException

最近在用MVC实现一些权限管理方面的东西,大概思路是继承AuthorizeAttribute写了一个子类UserAuthorizeAttribute,在需要验证的Action或controller中引用该Attribute。重写了三个方法,依执行顺序分别是OnAuthorization -> AuthorizeCore -&…

关于SQL的分组汇总统计(关键字 Grouping)

在做数据分组查询的时候我们经常会用到分组汇总查询,做个简单的例子: create table #bbb (大类 nvarchar(10),小类 nvarchar(10),酒水名称 nvarchar(20),数量 int,单价 Money) ----------------------------------------------------- insert into #bbb…

NSDate

1 //2 // main.m3 // NSDate4 //5 // Created by dingxiaowei on 13-5-17.6 // Copyright (c) 2013年 dingxiaowei. All rights reserved.7 //8 9 #import <Foundation/Foundation.h> 10 11 #pragma mark - 日期创建 12 void dateCreate(){ 13 //NSData表示字节…