ShardingSphere代码阅读(一)

本文介绍了ShardingSphere的基本概念,包括ShardingSphere的作用和功能。通过跑Demo,详细讲解了ShardingSphere-JDBC的API接口实现和配置文件实现,以及ShardingSphere-Proxy的配置和服务启动。强调了ShardingSphere-UI在管理和高可用性方面的重要性。文章结尾提醒读者注意关键字处理,避免数据库错误。
摘要由CSDN通过智能技术生成

ShardingSphere代码阅读(一)


前言

为什么会选择阅读ShardingSphere的源码呢?其实可以说机缘巧合下,在之前报的课程中有人带,并且是一个小团体进行阅读还有分享的,并且以前没有源码阅读经验,这次参与刚好作为一次开始,大家互相监督可以坚持下去这是最重要的。
引用老师说的一句话:“一个人可以走很快,一群人却可以走很远”,坚持努力总不会错的,共勉!

一、ShardingSphere是什么?

想学习一样新的东西,无非就是以下五步,前四步就够,第五步就是看个人的了

  1. 首先需知道这个东西的存在,如果连知道都不知道,更不要说学习,所以我知道了ShardingSphere,那么就完成第一步
  2. 知道了ShardingSphere后,那么就是去了解它到底是干什么的,能干什么的,在官网都能看到
    1.1、ShardingSphere官网:https://shardingsphere.apache.org/
    1.2、GitHub地址:https://github.com/apache/shardingsphere
  3. 初步了解ShardingSphere的工作原理功能效果后,为了加深印象,就需要根据官方的文档去跑demo,这一步很重要,如果不愿意跑一次demo,那么就没后面的事情的,亲身体验效果才能更容易领悟,也为阅读源码走出第一步。
  4. 跑完demo之后,就是思考为什么会得到这个结果,这个结果是怎么实现的,这里就是进入源码阅读的入口,需要思考这个过程,带着疑问深入了解,去源码查找答案
  5. 达到了一定程度,就是需要理解实现原理,这步是拆解整个框架的组成,并且思考着能不能自己也实现一个类似功能的工具,不在本文的范围(其实这里就达到架构师的门槛和成为开源社区项目committer的重要一环)

二、跑Demo

ShardingSphere有JDBC,Proxy和UI三部分,分别看看

1.ShardingSphere-JDBC

ShardingSphere的demo发现了五种不同的类型:

  • 分库(SHARDING_DATABASES)
  • 分表(SHARDING_TABLES)
  • 分库分表(SHARDING_DATABASES_AND_TABLES)
  • 读写分离(READWRITE_SPLITTING)
  • 分库读写分离(SHARDING_READWRITE_SPLITTING)
  • 外加一种特殊的类型:加密(Encrypt_Databases)

1.1.API接口实现

实例化代码如下:

public static DataSource newInstance(final ShardingType shardingType) throws SQLException {
   
        switch (shardingType) {
   
            case SHARDING_DATABASES:
                return new ShardingDatabasesConfigurationPrecise().getDataSource();
            case SHARDING_TABLES:
                return new ShardingTablesConfigurationPrecise().getDataSource();
            case SHARDING_DATABASES_AND_TABLES:
                return new ShardingDatabasesAndTablesConfigurationPrecise().getDataSource();
            case READWRITE_SPLITTING:
                return new ReadwriteSplittingConfiguration().getDataSource();
            case SHARDING_READWRITE_SPLITTING:
                return new ShardingReadwriteSplittingConfigurationPrecise().getDataSource();
            default:
                throw new UnsupportedOperationException(shardingType.name());
        }
    }

根据不同的shardingType去选择实例化数据源,里面处理实例化数据源之外,还需要分库分表,读写分离等规则,这些规则决定了如何实现相应的功能,选择分库分表作为解析,代码如下:

private ShardingRuleConfiguration createShardingRuleConfiguration() {
   
        ShardingRuleConfiguration result = new ShardingRuleConfiguration(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值