学习Sharding JDBC 从入门到出门-02:源码揣测

Posted 指针怒草内存栈

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学习Sharding JDBC 从入门到出门-02:源码揣测相关的知识,希望对你有一定的参考价值。

sjdbc有读写分离的功能,要使用这个功能,在创建数据源对象是要使用类:MasterSlaveDataSource,并且设置主备数据源和数据库名称

这个对象有下面的属性:

name:数据库的名称

masterDataSource:主数据源对象

slaveDataSources:备库数据源类别

slaveLoadBalanceStrategy:选从算法

 

 /**
     * 获取主或从节点的数据源名称.
     *
     * @param sqlStatementType SQL类型
     * @return 主或从节点的数据源
     */
    public DataSource getDataSource(final SQLStatementType sqlStatementType) {
        if (SQLStatementType.SELECT != sqlStatementType || DML_FLAG.get() || HintManagerHolder.isMasterRouteOnly()) {
            DML_FLAG.set(true);
            return masterDataSource;
        }
        return slaveLoadBalanceStrategy.getDataSource(name, slaveDataSources);
    }

 

以下三种情况下会走主库

(1)写走主库,读走从库
(2)当前线程,前面的操作走了主库,查询也要走主库。适用于进行了写的操作,然后接着查询的场景,这个时候如果读走从库,有可能会查询不到,因为主从的同步会有延迟
(3)使用Hint强制走主库
HintManager hintManager = HintManager.getInstance();
hintManager.setMasterRouteOnly();





以上是关于学习Sharding JDBC 从入门到出门-02:源码揣测的主要内容,如果未能解决你的问题,请参考以下文章

好课资源共享:15 mycat,sharding-jdbc从入门到精通更新完

云好课分享*mycat,sharding-jdbc从入门到精通更新完#百度网盘分享=会员免费

马士兵mca053:mycat,sharding-jdbc从入门到精通

mycat,sharding-jdbc从入门到精通马士兵教育

云好课分享!15 mycat,sharding-jdbc从入门到精通更新完*百度网盘分享/会员免费

萌萌合伙人15 mycat,sharding-jdbc从入门到精通更新完·面试·高清完整