先定几个原则/目标:

原则:

1.必须保证数据逻辑的一致性;

反例:刚写了数据,(因为主从延迟)查询不到;

2.对开发人员透明,对业务代码无侵入性;与单数据源的业务代码调用一致;

反例:对已有业务代码的侵入式改动,显示说明datasource;

3.根据调用场景自动选择主从数据源

场景:涉及写入,读写都在主库进行。只涉及查询,从库查询

反例:

3.1写事务调用从库

3.2非必要的从主库查询

4.给业务开发选择的权利,可以以最低成本的方式显示进行数据源(类别)选择(如annotation等);

场景:只涉及查询,但是业务需要,必须从主库查询;

5.主从数据源共存,与单数据源方案,可以无缝切换

扩展目标:

6.低成本的数据源切换线程安全

反例:全局悲观锁,同步锁实现

7.支持多个从库/从库HA

8.主数据库不可用,从库自动顶上

9.代码级别上,采用spring boot starter方案

不考虑场景:

sharding 目前不考虑,如果需要,作单独专题展开。

备忘问题:

传播级别:

调用者上下文显示说明MASTER,被调用者显示说明SLAVE; 或反过来,需要一个合理的切换机制/或者不切换;

传播性可以做如下规则:

1.如果外层为master,则内层不管原先级别,都将提升至master级别;

2.级别只升不降

3. 同一个线程,如果不切换主从,同一分类的机器,(主要是指多个slave )实例也不切换

4.更多的调用层级,直接递推即可(传播);

case:

  • master → slave        =>     master → master
  • master → master      =>     master → master
  • slave   → master       =>     slave → master
  • slave  → slave           =>     slave → slave

Master/Slave 切换场景的几种设定:

  默认Slave(性能优先) 默认Master(开发效率优先)

如果调用者未显示说明@Master/Slave,根据事务状态自主选择主从;

不在传播链中生成@Master/Slave

如果调用者未显示说明@Master/Slave,根据事务状态自主选择主从;

在传播链中生成@Master/Slave

优点

1.分担主库负担

2.尽可能利用从库,从库只读,HA成本低

1.现有代码无任何改动可正常运行

1.用户完全控制,截断了隐性的@Master

2.更多的@Slave场景机会

1.整个传播链行为一致,使得整个数据行为更一致;

缺点

所有现有的服务,涉及到写或者必须连master的场景,必须显示标明@Master;

否则会有两种情况:

1.涉及写入的时候会默认连接到只读从库,程序会报错;

2. 非写入动作,但可能有数据读取的延时性问题

1.需要显示标明@Slave,才能连接从库

2.从库利用率会较低

1.有可能业务逻辑的不一致;

例子:

a.不标明@Master/Slave 的调用上下文先执行了

写操作;

b.然后调用了@Slave 的读操作服务;

a步骤写入的数据,有可能在b操作中读取不出来

这种场景,当然可以通过显示标明调用者为
@Master 来规避;

1.对事务的状态判断,并不能单方面很好的决定是否选择主从,所以一般会选择主库;(TODO:看是否能更好优化)

2.为了程序运行逻辑不出异常的情况下,而大多选择了@Master,那么接下来的级别都会是@Master,@Slave 的场景会非常少,从库利用率会很低

项目地址:

https://github.com/leochowcomtop/db-proxy

springboot based 主从数据源中间件方案的更多相关文章

  1. springboot之多数据源配置JdbcTemplate

    springboot多数据源配置,代码如下 DataSourceConfig package com.rookie.bigdata.config; import org.springframework ...

  2. springboot配置Druid数据源

    springboot配置druid数据源 Author:SimpleWu springboot整合篇 前言 对于数据访问层,无论是Sql还是NoSql,SpringBoot默认采用整合SpringDa ...

  3. springBoot整合多数据源

    springBoot整合相关 1:springBoot整合多数据源: 应用场景:     项目需要同时连接两个不同的数据库A, B,并且它们都为主从架构,一台写库,多台读库. 工具/版本: jdk1. ...

  4. springboot + mybatis + 多数据源

    此文已由作者赵计刚薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1) ...

  5. 基于springboot的多数据源配置

    发布时间:2018-12-11   技术:springboot1.5.1 + maven3.0.1+ mybatis-plus-boot-starter2.3.1 + dynamic-datasour ...

  6. Spring主从数据源动态切换

    参考文档: http://uule.iteye.com/blog/2126533 http://lanjingling.github.io/2016/02/15/spring-aop-dynamicd ...

  7. Mysql读写分离与主从数据库设置方案

    Mysql读写分离与主从数据库设置方案 亿仁网 18-10-0711:31 Mysql无非四个功能:增,删,改,读.而将增删改和读分离操作.这样有利于提高系统性能.下面是非常直观的操作: 1.配置: ...

  8. Redis Sentinel主从高可用方案

    Redis Sentinel主从高可用方案 本文介绍一种通过Jed和Sentinel实现Redis集群(主从)的高可用方案,该方案需要使用Jedis2.2.2及以上版本(强制),Redis2.8及以上 ...

  9. springboot添加多数据源连接池并配置Mybatis

    springboot添加多数据源连接池并配置Mybatis 转载请注明出处:https://www.cnblogs.com/funnyzpc/p/9190226.html May 12, 2018  ...

随机推荐

  1. centos6删除nginx

    1.ps -ef|grep nginx 查看nginx进程 2.找到nginx相对应的位置 3.停止nginx服务: 4.删除nginx安装的相关路径(根据自己安装的情况来删除) 如果是yum安装,就 ...

  2. lnmp mysql远程访问设置

    一:iptables 设置开放3306访问 iptables -L -n --line-numbers 1,删除DROP 3306 iptables -D INPUT 5[序列号] 2,添加 ACCE ...

  3. 原创《如何用vue来轻松的驾驭 html5 webapp的页面体验》

    由于最近开始要做mobile的webapp 项目,所以利用周末的时间思考了下页面的体验问题,我主要参考了"微信"的页面体验,总结主要有2个页面切换效果(点击进入页面效果 和 返回上 ...

  4. JavaScript 中的 FileReader

    在不经过服务器的时候,本地预览照片,当确定以后再上传 它是H5提供的构造函数 用法: <input type='file'> <img src='' alt=''> <s ...

  5. 除了使用new关键字,还有什么方法可以创建Java对象呢?

    今天来盘点一下除了使用 "new" 关键字创建对象,还有什么方法可以创建Java对象呢? 因为是创建对象,所以这里ioc容器不在范围内 我们先看一下常用的new关键字创建 Clas ...

  6. Sonar 配置及部署(windows系统)

    Sonar 是一个用于代码质量管理的开放平台.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具. 与持续集成工具(例如 Hudson/Jenkins 等)不同,Sona ...

  7. 【GIT】【命令行】

    1) 进入某没有做git的目录: git init ->username@DESKTOP-765V31O MINGW64 ~/PycharmProjects/user_data (master) ...

  8. MySQL:(二)

    多表查询-笛卡尔积 对于数据库中 针对于两张表的记录数的所有记录进行匹配,获得笛卡尔积!⚠️笛卡尔积结果是无效的,必须从笛卡尔积中选取有效的数据结果 !!! -- 显示结果就是笛卡尔积,两个表记录乘积 ...

  9. mysql log and lock

    mysql bin log==> /etc/my.cnf==> log_bin=/var/log/mysql/mysql-bin.log==> binlog_do_db=your_d ...

  10. asp.net 虹软 人脸识别 实现刷脸住宿、刷脸签到、刷脸进入等

    先看看效果图,我把demo改成自动运行了,暂时借用别人的图片: 最左侧的大图为选择上传的, 中间的小图是大图的脸, 右侧的大图是人脸文件夹中已经存在的,并且相似度较高的一张脸,也就是比对的结果. 先记 ...