java相关:mysql+spring+mybatis实现数据库读写分离的代码配置

发布于 2020-4-4|

复制链接

分享一篇关于关于mysql+spring+mybatis实现数据库读写分离的代码配置,小妖觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小妖来看看吧

场景:一个读数据源一个读写数据源。原理:借助spring的【org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource】这个抽象类实现,看名字可以了解到是一个路由数据源的东西,这个类中有一个方法

```java

/**

* Determine the current lookup key. This will typically be

* implemented to check a thread-bound transaction context.

* Allows for arbitrary keys. The returned key needs

* to match the stored lookup key type, as resolved by the

* {@link #resolveSpecifiedLookupKey} method.

*/

protected abstract Object determineCurrentLookupKey();

```

每次去连数据库的时候,spring会调用这个方法去找对应的数据源。返回值即对应的数据源的LookUpKey.那么这个LookUpKey在哪定义的呢?看下面的dataBase.xml的配置

```xml

user=${jdbc.username},password=${jdbc.password}

user=${jdbc.r.username},password=${jdbc.r.password}

```

动态数据源dynamicDataSource中的dataSourceKeyRW、dataSourceKeyR就是

```java

protected abstract Object determineCurrentLookupKey();

```

这个方法要返回的值。那么如何设置,让这个方法的返回值是根据我们的需要返回dataSourceKeyRW、dataSourceKeyR呢?由于这个方法没有入参,并且是spring自动调用的,因此考虑使用静态变量存储dataSource的key,在调用sql语句前设置静态变量的值,然后在这个方法中得到静态变量的值,返回。又考虑到多线程,同时可能会有很多请求,为避免线程之间相互干扰,考虑使用threadLocal。先看存储dataSourceKey的容器类。

```java

public class DBContextHolder {

/**

* 线程threadlocal

*/

private static ThreadLocal contextHolder = new ThreadLocal();

private String DB_TYPE_RW = "dataSourceKeyRW";

private String DB_TYPE_R = "dataSourceKeyR";

public String getDbType() {

String db = contextHolder.get();

if (db == null) {

db = DB_TYPE_RW;// 默认是读写库

}

return db;

}

/**

* 设置本线程的dbtype

* @param str

* @see [相关类/方法](可选)

* @since [产品/模块版本](可选)

*/

public void setDbType(String str) {

contextHolder.set(str);

}

/**

* clearDBType

* @Title: clearDBType

* @Description: 清理连接类型

*/

public static void clearDBType() {

contextHolder.remove();

}

}

```

动态数据源的实现类。

```java

public class DynamicDataSource extends AbstractRoutingDataSource {

/*

* (non-Javadoc)

* @see javax.sql.CommonDataSource#getParentLogger()

*/

@Override

public Logger getParentLogger() throws SQLFeatureNotSupportedException {

// TODO Auto-generated method stub

return null;

}

/**

* override determineCurrentLookupKey

*

* Title: determineCurrentLookupKey

*

*

* Description: 自动查找datasource

*

* @return

*/

@Override

protected Object determineCurrentLookupKey() {

return DBContextHolder.getDbType();

}

}

```

在DAO层中设置数据库类型。

```java

/**

* 添加邮件

* @param sms

* @return

*/

public boolean insertEmail(Email email) {

//根据具体需要设置不同的数据库

DBContextHolder.setDbType(DBContextHolder.DB_TYPE_RW);

//DBContextHolder.setDbType(DBContextHolder.DB_TYPE_R);

int result = this.getSqlSession().insert(STATEMENT + ".addEntity",

email);

return result == 1;

}

```

java spring mysql配置_java相关:mysql+spring+mybatis实现数据库读写分离的代码配置相关推荐

  1. java+cache使用方法_java相关:Spring boot redis cache的key的使用方法

    java相关:Spring boot redis cache的key的使用方法 发布于 2020-8-16| 复制链接 摘记: 在数据库查询中我们往往会使用增加缓存来提高程序的性能,@Cacheabl ...

  2. java spring注入 静态方法_java相关:spring为类的静态属性实现注入实例方法

    java相关:spring为类的静态属性实现注入实例方法 发布于 2020-3-31| 复制链接 在本篇文章里小妖给大家整理的是关于spring为类的静态属性实现注入实例方法,有需要的朋友们可以参考下 ...

  3. java方法设置切点_java相关:Spring AOP中定义切点的实现方法示例

    java相关:Spring AOP中定义切点的实现方法示例 发布于 2020-6-6| 复制链接 摘记: 本文实例讲述了Spring AOP中定义切点的实现方法.分享给大家供大家参考,具体如下:一 配 ...

  4. mysql+spring+mybatis实现数据库读写分离[代码配置] .

    场景:一个读数据源一个读写数据源. 原理:借助spring的[org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource] ...

  5. java签到 表设计_java springboot 7天签到功能设计 数据库表设计 加代码

    实现一个类似于这样的签到功能 (参考的百度网盘签到页面) 数据表是一个用户只有一条签到记录的设计, 没有使用签到一次表中加一条数据, 那样的话数据太多了 表结构: CREATE TABLE `sign ...

  6. thinkphp mysql读写分离_ThinkPHP5分布式数据库读写分离

    项目想要数据库读写分离,需要配置两个方面,一个是数据库配置,另一个是ThinkPHP5配置,前面写过一篇关于MySQL读写分离配置的文章MySQL主从同步及读写分离,这篇介绍ThinkPHP5里怎么运 ...

  7. mysql读写分离java配置方法_springboot配置数据库读写分离

    为什么要做数据库读写分离 大多数互联网业务,往往读多写少,这时候,数据库的读会首先称为数据库的瓶颈,这时,如果我们希望能够线性的提升数据库的读性能,消除读写锁冲突从而提升数据库的写性能,那么就可以使用 ...

  8. mybatis获取mysql源数据类型_spring集成mybatis实现mysql数据库读写分离

    前言 在网站的用户达到一定规模后,数据库因为负载压力过高而成为网站的瓶颈.幸运的是目前大部分的主流数据库都提供主从热备功能,通过配置两台数据库主从关系,可以将一台数据库的数据更新同步到另一台服务器上. ...

  9. Spring - 数据库读写分离

    文章目录 Spring - 数据库读写分离 1.读写分离解决方案 1.1 应用层解决 1.2 中间件解决 2.Mysql主从配置 2.1 Mysql主从复制原理 2.2 Master主库配置 2.3 ...

最新文章

  1. python 培训-本人的Python自学历程分享
  2. Split in Java
  3. 【算法】有关点分治的一些理解与看法
  4. 几个用于序列化的代码片段
  5. vue 怎么清空依赖_vuejs如何在把对象所有属性清空?
  6. 解决:Error response from daemon: Cannot restart container xxx: driver failed programming external
  7. 可以查python题的_Python练习题4.9查询水果价格
  8. js 经常用到的键盘码
  9. 可下拉选项可模糊查询的文本输入框
  10. Vue:vue组件生命周期
  11. 硬软链接的区别 节点 以及重定向和管道
  12. 【python】字符串转换整数 (atoi) - String
  13. 各区区号的字段和名称
  14. ArcEngine添加指北针
  15. php 招聘要求 转载
  16. 上蔡一高2021高考成绩查询,喜报!上蔡高考英雄榜出炉!
  17. Gopher China 2019 讲师专访-Grab/地图团队资深架构师胡泊
  18. Ionic + Vue3 + Capacitor 配置环境、打包应用常见问题
  19. 哈理工 校赛(热身赛)2238 围巾的纠结(判断回路问题)
  20. 电快速瞬变脉冲群实验(内部电源设备)

热门文章

  1. boost::detail::yield相关的测试程序
  2. boost::static_mutex 的测试程序
  3. boost::mpl模块BOOST_MPL_ASSERT_MSG相关的测试程序
  4. boost::intrusive::get_parent_from_member用法的测试程序
  5. boost::fusion::filter_view用法的测试程序
  6. VTK:Utilities之RenderScalarToFloatBuffer
  7. VTK:绘图之PlotLine3D
  8. OpenCV Gunnar Farneback的密集光流算法(附完整代码)
  9. QT的QStatusBar类的使用
  10. QT的QPair类的使用