持久化框架:轻量级的关系型数据库中间件 Sharding-JDBC

框架介绍
sharding-jdbc 是一个轻量级的关系型数据库中间件,提供分库分表、读写分离和柔性事务等功能。它直接封装 jdbc 协议,可以理解为增强版的 jdbc 驱动,旧代码迁移成本几乎为零。它使用客户端直连数据库,以 jar 包形式提供服务,无 proxy 代理层,无需额外部署,无其他依赖,dba 也无需改变原有的运维方式。
sharding-jdbc 是当当应用框架 ddframe 中,从关系型数据库模块 dd-rdb 中分离出来的数据库水平分片框架,实现透明化数据库分库分表访问。sharding-jdbc 是继 dubbox 和 elastic-job 之后,ddframe 系列开源的第 3 个项目。
主要包括以下特点:
可适用于任何基于 java 的 orm 框架,如:jpa, hibernate, mybatis, spring jdbc template 或直接使用 jdbc。
可基于任何第三方的数据库连接池,如:dbcp, c3p0, bonecp, druid 等。
理论上可支持任意实现 jdbc 规范的数据库。虽然目前仅支持 mysql,但已有支持 oracle,sql server 等数据库的计划。
分片策略灵活,可支持等号,between,in 等多维度分片,也可支持多分片键。
sql 解析功能完善,支持聚合,分组,排序,limit,or 等查询,并支持 binding table 以及笛卡尔积表查询。
性能高。单库查询 qps 为原生 jdbc 的 99.8%;双库查询 qps 比单库增加94%。
架构图
sharding-jdbc和好的解决了分库分表的问题,并且支持大部分的sql已完全够用。而且比较灵活,有分表策略配置和分裤策略配置,开发文档也将的非常详细,清楚,并提供了demo,简单易用且实用性很好,大赞!!!
与常见开源产品对比
这里仅列出目前停止更新,但仍然在数据库分片领域非常有影响力的几个项目。
功能
cobar
cobar-client
tddl
sharding-jdbc
分库

未开源
分表

中间层


orm支持
任意
仅mybatis
数据库支持
仅mysql
异构语言

仅java
外部依赖
diamond
sharding-jdbc严格遵循apache 2.0许可证的要求。测试覆盖率95%,目前已部署至maven中央仓库。可使用以下坐标引用:
com.dangdangsharding-jdbc-core1.0.0
sharding-jdbc将保持持续更新,后续会完善读写分离、柔性分布式事务和高可用等相关功能。
最新情况
sharding-jdbc 1.5.4 正式发布。作为分布式数据库中间件,它关注如何简化分布式数据库带来的复杂度,让工程师象使用单一数据库一样使用分布式的数据库。它完整的实现了分库分表、读写分离、分布式主键、柔性事务等功能,让您的数据库应用具备透明化的可水平扩展的能力。
1.5.4的主要更新是bug的修复,让1.5.x版本更加稳定,详细更新请参见release notes。如果再无紧急issue需要修复,它将是1.x的最终版本。
sharding-jdbc即将进入2.0时代,整体包名将修改为io.shardingjdbc,包括码云的项目仓库也会随之迁移至https://gitee/shardingjdbc。目前开发进度已到2.0.0.m1发布的中段,欢迎大家边看源码边讨论。
感谢开源中国对sharding-jdbc长期以来的支持,目前sharding-jdbc在github的star数已经接近2800,而在码云上却仅有500多的star,真诚邀请大家为sharding-jdbc在码云上star一下,以鞭策我们做的更好