网站首页 > 开源技术 正文
Sharding-JDBC
官网:https://shardingsphere.apache.org/document/legacy/4.x/document/cn/overview/
定位为轻量级Java框架,在Java的JDBC层提供的额外服务。 它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。
- 适用于任何基于JDBC的ORM框架,如:JPA, Hibernate, Mybatis, Spring JDBC Template或直接使用JDBC。
- 支持任何第三方的数据库连接池,如:DBCP, C3P0, BoneCP, Druid, HikariCP等。
- 支持任意实现JDBC规范的数据库。目前支持MySQL,Oracle,SQLServer,PostgreSQL以及任何遵循SQL92标准的数据库。
Maven依赖
<!-- 测试库 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- web容器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- shardingsphere common 库 -->
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>shardingsphere-common</artifactId>
<version>4.1.0</version>
</dependency>
<!-- shardingsphere jdbc spring 集成库 -->
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>sharding-jdbc-spring-boot-starter</artifactId>
<version>4.1.0</version>
</dependency>
<!-- 阿里巴连接池 druid-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.9</version>
</dependency>
<!-- lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok}</version>
</dependency>
<!-- mysql 驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- mybatis plus 引用 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.0.6</version>
</dependency>
<!-- velocity 自动生成模板引擎, 默认 -->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.0</version>
</dependency>
<!-- freemarker 自动生成 模板引擎 -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.28</version>
</dependency>
读写分离配置
spring:
profiles:
active: test
shardingsphere:
props:
sql:
show: true ## 打印sql信息
# 配置真实数据源
dataSource:
names: ds0,ds1
ds0: # 配置写数据源
type: com.alibaba.druid.pool.DruidDataSource ##使用Druid连接池
driver-class-name: com.mysql.jdbc.Driver # 配置mysql驱动
url: jdbc:mysql://xxx-xxx-xxx.xxx.xxx:3306/ds0?characterEncoding=utf-8&useSSL=false
username: root ##mysql用户名
password: xxx ##mysql密码
# 配置第 2 个数据源
ds1:
type: com.alibaba.druid.pool.DruidDataSource # 配置读数据源
driver-class-name: com.mysql.jdbc.Driver # 使用Druid连接池
url: jdbc:mysql://xxx-xxx-xxx.xxx.xxx:3306/ds1?characterEncoding=utf-8&useSSL=false
username: root ##mysql用户名
password: xxx mysql密码
masterslave:
load-balance-algorithm-type: round_robin ##使用轮训算法
name: ds0 ##
master-data-source-name: ds0 #写库
slave-data-source-names: ds1 #读库
启动类配置
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure;
import lombok.extern.slf4j.Slf4j;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@Slf4j
//加载mapper文件包
@MapperScan(basePackages = { "com.xxx.xxx.jdbc.business.user.mapper" })
//取消数据源自动配置,我们使用shardingsphere-jdbc配置数据源
@SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class)
public class JdbcApplication {
public static void main(String[] args) {
SpringApplication.run(JdbcApplication.class, args);
log.info( "启动成功" );
}
}
运行结果
核心概念
主库
添加、更新以及删除数据操作所使用的数据库,目前仅支持单主库。
从库
查询数据操作所使用的数据库,可支持多从库。
主从同步
将主库的数据异步的同步到从库的操作。由于主从同步的异步性,从库与主库的数据会短时间内不一致。
负载均衡策略
通过负载均衡策略将查询请求疏导至不同从库。
猜你喜欢
- 2025-01-07 几个简单法则,让春装更“出色”
- 2025-01-07 BF仔裤要穿的帅 但是不要真的穿成蓝朋友!
- 2025-01-07 正畸治疗后的牙间黑三角
- 2025-01-07 解放双脚 从一双Espadrilles渔夫鞋开始
- 2025-01-07 自古红蓝出CP 其实还能加一点黑&白!
- 2025-01-07 呦呦呦,杨幂用连帽衫加棒球帽好时髦,开春我要变酷酷“少女风”
- 2025-01-07 穿搭套路深 总是有新CP能给你惊喜!
- 2025-01-07 路医生说|急性跟腱断裂要不要手术,如何更快康复?
- 2025-01-07 MyBatis整合Springboot多数据源实现
- 2025-01-07 sharding-jdbc分库分表及读写分离
你 发表评论:
欢迎- 05-16东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 05-16这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 05-16湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- 05-16Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- 05-16G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- 05-16DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 05-16上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- 05-16WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 最近发表
-
- 东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 湖人自媒体调查:89%球迷希望DFS回归 79%希望詹姆斯回归
- 一觉醒来湖人苦盼的纯3D终于到位 DFS能带给紫金军多少帮助
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)