ssm使用双数据源
工作中需要接入其他公司业务系统的数据进行分析,于是接入它们的db。
使用双数据源配置感觉如下:
database、sessionFactory、扫描器、事务管理器等双份。 听说如果两个数据源需要一起使用加事务的时候有点恶心,没有遇到该业务问题所以没有深入。
具体配置:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean class="com.kunpu.appopm.dal.config.JDBCPlaceholderConfigurer">
<property name="order" value=""/>
<property name="ignoreUnresolvablePlaceholders" value="true"/>
<property name="location" value="file:/opt/configs/appopm/datasource.properties"/>
</bean> <bean id="dataSource1" class="com.alibaba.druid.pool.DruidDataSource"
init-method="init" destroy-method="close">
<property name="driverClassName" value="${datasource.driverClassName}"/>
<property name="url" value="${datasource1.url}"/>
<property name="username" value="${datasource1.username}"/>
<property name="password" value="${datasource1.password}"/>
<property name="connectionProperties" value="${datasource.connectionProperties}"/>
<property name="initialSize" value="${datasource.initialsize}"/>
<property name="maxActive" value="${datasource.maxActive}"/>
<property name="minIdle" value="${datasource.minIdle}"/>
<property name="maxWait" value="${datasource.maxWait}"/>
<property name="validationQuery" value="SELECT 1 FROM DUAL"/>
<property name="testOnBorrow" value="${datasource.testOnBorrow}"/>
<property name="testOnReturn" value="${datasource.testOnReturn}"/>
<property name="testWhileIdle" value="${datasource.testWhileIdle}"/>
<property name="timeBetweenEvictionRunsMillis"
value="${datasource.timeBetweenEvictionRunsMillis}"/>
<property name="minEvictableIdleTimeMillis"
value="${datasource.minEvictableIdleTimeMillis}"/>
<property name="removeAbandoned" value="${datasource.removeAbandoned}"/>
<property name="removeAbandonedTimeout" value="${datasource.removeAbandonedTimeoutMillis}"/>
<property name="logAbandoned" value="${datasource.logAbandoned}"/>
<property name="filters" value="${datasource.filters}"/>
<property name="poolPreparedStatements" value="${datasource.poolPreparedStatements}"/>
<property name="maxPoolPreparedStatementPerConnectionSize"
value="${datasource.maxPoolPreparedStatementPerConnectionSize}"/>
</bean> <bean id="sessionFactory1" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource1"/>
<property name="configLocation" value="classpath:/configs/mybatis-config.xml"/>
<property name="mapperLocations">
<list>
<value>classpath:/mapper1/**/*.xml</value>
</list>
</property>
<property name="typeAliasesPackage" value="com.kunpu.appopm.dal.model"/>
<property name="plugins">
<list>
<bean class="com.kunpu.appopm.common.util.log.SQLLogInterceptor"/>
<bean class="com.kunpu.frameworks.cat.util.CatDBInterceptor"/>
<bean class="com.kunpu.frameworks.db.pagination.PaginationInterceptor">
<property name="dialect">
<bean class="com.kunpu.frameworks.db.pagination.MySqlDialect"/>
</property>
</bean>
</list>
</property>
</bean> <bean id="scanner1" class="tk.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="sessionFactory1"/>
<property name="basePackage" value="com.kunpu.appopm.dal"/>
<property name="annotationClass" value="com.kunpu.appopm.dal.config.BaseDB"/>
<property name="properties">
<value>
mappers=tk.mybatis.mapper.common.Mapper
IDENTITY=MYSQL
notEmpty=true
</value>
</property>
</bean> <bean id="sqlSessionTemplate1" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="" ref="sessionFactory1"/>
</bean> <bean id="transactionManager1"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource1"/>
</bean> <!-- 事务模板 -->
<bean id="transactionTemplate1"
class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transactionManager1"/>
<constructor-arg name="transactionManager" ref="transactionManager1"/>
</bean> <bean id="dataSource2" class="com.alibaba.druid.pool.DruidDataSource"
init-method="init" destroy-method="close">
<property name="driverClassName" value="${datasource.driverClassName}"/>
<property name="url" value="${datasource2.url}"/>
<property name="username" value="${datasource2.username}"/>
<property name="password" value="${datasource2.password}"/>
<property name="connectionProperties" value="${datasource.connectionProperties}"/>
<property name="initialSize" value="${datasource.initialsize}"/>
<property name="maxActive" value="${datasource.maxActive}"/>
<property name="minIdle" value="${datasource.minIdle}"/>
<property name="maxWait" value="${datasource.maxWait}"/>
<property name="validationQuery" value="SELECT 1 FROM DUAL"/>
<property name="testOnBorrow" value="${datasource.testOnBorrow}"/>
<property name="testOnReturn" value="${datasource.testOnReturn}"/>
<property name="testWhileIdle" value="${datasource.testWhileIdle}"/>
<property name="timeBetweenEvictionRunsMillis"
value="${datasource.timeBetweenEvictionRunsMillis}"/>
<property name="minEvictableIdleTimeMillis"
value="${datasource.minEvictableIdleTimeMillis}"/>
<property name="removeAbandoned" value="${datasource.removeAbandoned}"/>
<property name="removeAbandonedTimeout" value="${datasource.removeAbandonedTimeoutMillis}"/>
<property name="logAbandoned" value="${datasource.logAbandoned}"/>
<property name="filters" value="${datasource.filters}"/>
<property name="poolPreparedStatements" value="${datasource.poolPreparedStatements}"/>
<property name="maxPoolPreparedStatementPerConnectionSize"
value="${datasource.maxPoolPreparedStatementPerConnectionSize}"/>
</bean> <bean id="scanner2" class="tk.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="sessionFactory2"/>
<property name="basePackage" value="com.kunpu.appopm.dal"/>
<property name="annotationClass" value="com.kunpu.appopm.dal.config.BaseDB2"/>
<property name="properties">
<value>
mappers=tk.mybatis.mapper.common.Mapper
IDENTITY=MYSQL
notEmpty=true
</value>
</property>
</bean> <bean id="sessionFactory2" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource2"/>
<property name="configLocation" value="classpath:/configs/mybatis-config.xml"/>
<property name="mapperLocations">
<list>
<value>classpath:/mapper2/**/*.xml</value>
</list>
</property>
<property name="typeAliasesPackage" value="com.kunpu.appopm.dal.model"/>
<property name="plugins">
<list>
<bean class="com.kunpu.appopm.common.util.log.SQLLogInterceptor"/>
<bean class="com.kunpu.frameworks.cat.util.CatDBInterceptor"/>
<bean class="com.kunpu.frameworks.db.pagination.PaginationInterceptor">
<property name="dialect">
<bean class="com.kunpu.frameworks.db.pagination.MySqlDialect"/>
</property>
</bean>
</list>
</property>
</bean> <bean id="sqlSessionTemplate2" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="" ref="sessionFactory2"/>
</bean> <bean id="transactionManager2"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource2"/>
</bean> <!-- 事务模板 -->
<bean id="transactionTemplate2"
class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transactionManager1"/>
<constructor-arg name="transactionManager" ref="transactionManager1"/>
</bean>
这里扫描指定dao使用的是basePage配合指定注解,应该是一点亮点吧。
ssm使用双数据源的更多相关文章
- Spring Boot 集成 Mybatis 实现双数据源
这里用到了Spring Boot + Mybatis + DynamicDataSource配置动态双数据源,可以动态切换数据源实现数据库的读写分离. 添加依赖 加入Mybatis启动器,这里添加了D ...
- spring+mybatis 配置双数据源
配置好后,发现网上已经做好的了, 不过,跟我的稍有不同, 我这里再拿出来现个丑: properties 文件自不必说,关键是这里的xml: <?xml version="1.0&quo ...
- Spring Boot2.4双数据源的配置
相较于单数据源,双数据源配置有时候在数据分库的时候可能更加有利 但是在参考诸多博客以及书籍(汪云飞的实战书)的时候,发现对于spring boot1.X是完全没问题的,一旦切换到spring boot ...
- spring项目配置双数据源读写分离
我们最早做新项目的时候一直想做数据库的读写分离与主从同步,由于一些原因一直没有去做这个事情,这次我们需要配置双数据源的起因是因为我们做了一个新项目用了另一个数据库,需要把这个数据库的数据显示到原来的后 ...
- Spring Boot集成Mybatis双数据源
这里用到了Spring Boot + Mybatis + DynamicDataSource配置动态双数据源,可以动态切换数据源实现数据库的读写分离. 添加依赖 加入Mybatis启动器,这里添加了D ...
- MyBatis整合双数据源
有时候在项目中会遇到需要连接两个数据库的情况.本文就结合Spring和Mybatis来讲下怎么使用双数据源(或者是多数据源). 背景知识介绍 本文中实现多数据源的关键是Spring提供的Abstrac ...
- SSM动态切换数据源
有需求就要想办法解决,最近参与的项目其涉及的三个数据表分别在三台不同的服务器上,这就有点突兀了,第一次遇到这种情况,可这难不倒笔者,资料一查,代码一打,回头看看源码,万事大吉 1. 预备知识 这里默认 ...
- spring-boot支持双数据源mysql+mongo
这里,首先想说的是,现在的web应用,处理的数据对象,有结构化的,也有非结构化的.同时存在.但是在spring-boot操作数据库的时候,若是在properties文件中配置数据源的信息,通过默认配置 ...
- MyBatis双数据源配置
配置相关 jdbc 配置 #============================================================================ # MySQL # ...
随机推荐
- Lab 3-2
Analyze the malware found in the file Lab03-02.dll using basic dynamic analysis tools. Questions and ...
- LeetCode--242--有效的字母异位词
问题描述: 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词. 示例 1: 输入: s = "anagram", t = "nagara ...
- 11月28日 记录一个错误❌,看ruby on rails --active support core extensions--present? && presence && duplicable?
❌错误 1. @job.resume.count: 提示❌ undefined method `resume' ✅: @job.resumes.count //解释:调出某一个job的所有简历, ...
- Windows 上安装 Scala
在安装 Scala 之前需要先安装 Java 环境,具体安装的详细方法就不在这里描述了. 您可以自行搜索我们网站中的内容获得其他网站的帮助来获得如何安装 Java 环境的方法. 接下来,我们可以从 S ...
- 反射API(一)
<?php function classData(ReflectionClass $class) { echo '<hr>'; $details = '当前文件:'; $detail ...
- New task CodeForces - 788E (线段树优化dp)
比较套路的一个题, 对每个数维护一颗线段树来转移就好了. #include <iostream> #include <algorithm> #include <cstdi ...
- JS代码判断IE6,IE7,IE8,IE9
做网页有时候会用到JS检测IE的版本,下面是检测Microsoft Internet Explorer版本的三种代码! 有一种代码: <script type="text/javasc ...
- Spring Boot项目打包部署到外部Tomcat
1.生成war包 1)修改POM文件,将打包类型改为war:<packaging>war</packaging> <packaging>war</packag ...
- OCP知识点讲解 之 检查点队列与增量检查点
原创 http://blog.chinaunix.net/uid-26762723-id-3271558.html 检查点的主要目的是以对数据库的日常操作影响最小的方式刷新脏块.脏块不断的产生,如何将 ...
- centos命令行系列之升级glibc到
1.从http://ftp.gnu.org/gnu/glibc/glibc-2.17.tar.gz 下载文件 2.安装部署 [root@kafzook1 /]# tar -xf glibc-2.17. ...