springmvc 定时器 多数据源
0.目的:测试网上多数据源切换代码靠不靠谱
1.先说需求:根据摄像头采集到的数据,做一些业务上的特定处理,但是,但是很重要,摄像采集数据不直接存在此数据库,需要定时的去外部DB去取数据,这就涉及到多数据源,和spring定时器
2.直接上代码了
多数据源配置文件 (重要的代码已上色)
<!-- DataSource -->
<bean id="dataSource1" class="org.apache.tomcat.dbcp.dbcp2.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
<bean id="dataSource2" class="org.apache.tomcat.dbcp.dbcp2.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver1}" />
<property name="url" value="${jdbc.url1}" />
<property name="username" value="${jdbc.username1}" />
<property name="password" value="${jdbc.password1}" />
</bean>
<bean id="dataSource" class="com.ryuantech.mp.common.DynamicDataSource" >
<property name="targetDataSources">
<map key-type="java.lang.String">
<!--通过不同的key决定用哪个dataSource-->
<entry value-ref="dataSource1" key="dataSource1"></entry>
<entry value-ref="dataSource2" key="dataSource2"></entry>
</map>
</property>
<!--设置默认的dataSource-->
<property name="defaultTargetDataSource" ref="dataSource1">
</property>
</bean> <!--sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="mapperLocations">
<array>
<value>classpath:sqlmap/**/*.xml</value>
</array>
</property>
<property name="configLocation" value="classpath:mybatis-config.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
<!-- transactionManager -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<!-- enable transaction annotation support -->
<tx:annotation-driven transaction-manager="transactionManager" />
<!-- spring thread pool executor -->
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<!-- 线程池维护线程的最少数量 -->
<property name="corePoolSize" value="100" />
<!-- 允许的空闲时间 -->
<property name="keepAliveSeconds" value="60" />
<!-- 线程池维护线程的最大数量 -->
<property name="maxPoolSize" value="2000" />
<!-- 缓存队列 -->
<property name="queueCapacity" value="50" />
<!-- 对拒绝task的处理策略 -->
<property name="rejectedExecutionHandler">
<bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />
</property>
</bean>
定时器配置文件
头问价下面的代码必要
xmlns:task="http://www.springframework.org/schema/task"
http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.2.xsd <!-- 定时器 -->
<task:annotation-driven/>
<context:component-scan base-package="com.ryuantech.mp.task"></context:component-scan>
数据源切换类代码
public class DynamicDataSource extends AbstractRoutingDataSource { private static final ThreadLocal<String> contextHolder = new ThreadLocal<>(); @Override
protected Object determineCurrentLookupKey() {
String dataSource = getDataSource();
return dataSource;
} /**
* 设置数据源
*
* @param dataSource
*/
public static void setDataSource(String dataSource) {
System.out.println("设置数据源:"+dataSource);
contextHolder.set(dataSource);
} /**
* 获取数据源
*
* @return
*/
public static String getDataSource() {
String dataSource = contextHolder.get();
System.out.println("获取数据源:"+dataSource);
// 如果没有指定数据源,使用默认数据源
if (null == dataSource) {
DynamicDataSource.setDataSource("dataSource1");
}
return contextHolder.get();
} /**
* 清除数据源
*/
public static void clearDataSource() {
contextHolder.remove();
} }
定时器(切换到他DB)测试类
@Component("task")
public class FaceTask { @Autowired
private FacecaptureinfoOthersService otherService; @Autowired
private FacecaptureinfoService faceService; @Scheduled(cron = "0/5 * * * * ? ") // 间隔5秒执行
public void getFaceInfoFromOthers() throws InterruptedException { Facecaptureinfo info = new Facecaptureinfo();
for (int i= 0;i<20;i++) {
info.setDevid(1);
info.setVisitorid(Integer.parseInt("2"+i));
info.setTime(new Date());
otherService.selectBySelectedFromOther(i);
}
}
}
定时器(切换到他DB)测试类
@Service
public class FacecaptureinfoOthersServiceImpl implements FacecaptureinfoOthersService{ @Autowired
private FacecaptureinfoMapper faceMapper; @Override
public List<Facecaptureinfo> selectBySelectedFromOther(int i) {
// DynamicDataSource.setDataSource("dataSource2");
// List<Facecaptureinfo> list = faceMapper.selectBySelectedFromOthers(record);
// DynamicDataSource.setDataSource("dataSource1");
// return list;
List<Facecaptureinfo> list = new ArrayList<Facecaptureinfo>();
SimpleDateFormat sdf = new SimpleDateFormat("YYYY/MM/dd HH:mm:ss.SSS"); System.out.println("selectBySelectedFromOther:开始");
System.out.println("selectBySelectedFromOther:开始时间"+sdf.format(new Date()));
DynamicDataSource.setDataSource("dataSource2");
System.out.println("selectBySelectedFromOther:" + i);
try {
Thread.sleep(150);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
DynamicDataSource.setDataSource("dataSource1");
System.out.println("selectBySelectedFromOther:结束");
System.out.println("selectBySelectedFromOther:结束时间"+sdf.format(new Date()));
return list;
}
}
本DB测试类(为了方便就直接在页面上用js定时器访问了)
js文件
function checkWaring()
{
var basePath = document.getElementById('basePath').value;
$.ajax({
type : "POST",
url : basePath + "/visitor/initVisitorReg",
data : {
"phone" : 151,
"imsi" : 121
},
dataType : "json",
success : function(data) {},
error : function(data){
console.log(data);
}
});
} $(document).ready(function(){ $(document).ready(function(){
setInterval ("checkWaring()", 1000);
});
});
后台代码
@RequestMapping(path = "/initVisitorReg", method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> initVisitorReg() {
// logger.info("访客登记:开始--/initVisitorReg");
Map<String, Object> map = new HashMap<String, Object>();
for (int i = 0; i<20;i++) {
System.out.println("initVisitorReg-开始");
System.out.println(DynamicDataSource.getDataSource());
System.out.println("initVisitorReg" + i);
System.out.println("initVisitorReg-结束");
if (i == 10) {
try {
Thread.sleep(250);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
3 思路:进行DB切换的类:5秒内切换20次,为了尽量的用足了5秒来模仿取数据时候的DB I/O花费的时间,切换一次用足了的话就是250毫秒,留了点BUFFER的话,就线程睡眠了150毫秒
不进行DB切换的类:一秒内执行for循环20次,为了尽量仿真,访问到第十次的时候让他睡眠250毫秒,尽量让他们有交集
4 实验结果
initVisitorReg-结束
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:00.606
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:00.606
设置数据源:dataSource2
selectBySelectedFromOther:4
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:00.756
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:00.756
设置数据源:dataSource2
selectBySelectedFromOther:5
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:00.907
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:00.908
设置数据源:dataSource2
selectBySelectedFromOther:6
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.058
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.058
设置数据源:dataSource2
selectBySelectedFromOther:7
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.209
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.209
设置数据源:dataSource2
selectBySelectedFromOther:8
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg0
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg1
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg2
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg3
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg4
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg5
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg6
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg7
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg8
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg9
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg10
initVisitorReg-结束
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.359
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.359
设置数据源:dataSource2
selectBySelectedFromOther:9
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg11
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg12
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg13
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg14
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg15
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg16
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg17
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg18
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg19
initVisitorReg-结束
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.511
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.512
设置数据源:dataSource2
selectBySelectedFromOther:10
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.665
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.665
设置数据源:dataSource2
selectBySelectedFromOther:11
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.815
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.815
设置数据源:dataSource2
selectBySelectedFromOther:12
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:01.965
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:01.966
设置数据源:dataSource2
selectBySelectedFromOther:13
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.116
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.116
设置数据源:dataSource2
selectBySelectedFromOther:14
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg0
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg1
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg2
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg3
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg4
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg5
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg6
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg7
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg8
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg9
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg10
initVisitorReg-结束
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.266
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.266
设置数据源:dataSource2
selectBySelectedFromOther:15
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.416
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.417
设置数据源:dataSource2
selectBySelectedFromOther:16
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg11
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg12
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg13
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg14
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg15
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg16
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg17
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg18
initVisitorReg-结束
initVisitorReg-开始
获取数据源:dataSource1
dataSource1
initVisitorReg19
initVisitorReg-结束
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.568
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.568
设置数据源:dataSource2
selectBySelectedFromOther:17
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.718
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.718
设置数据源:dataSource2
selectBySelectedFromOther:18
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:02.868
selectBySelectedFromOther:开始
selectBySelectedFromOther:开始时间2018/04/27 12:16:02.868
设置数据源:dataSource2
selectBySelectedFromOther:19
设置数据源:dataSource1
selectBySelectedFromOther:结束
selectBySelectedFromOther:结束时间2018/04/27 12:16:03.018
结论:网上代码还是比较靠谱的,基本上不会出现在定时器切换数据源的时候,造成本系统数据源紊乱的.
springmvc 定时器 多数据源的更多相关文章
- SpringMVC配置双数据源,一个java项目同时连接两个数据库
数据源在配置文件中的配置 请点击---> java架构师项目实战,高并发集群分布式,大数据高可用,视频教程 <pre name="code" class=" ...
- Spring+Mybatis+SpringMVC+Atomikos多数据源共存+不同数据库事物一致性处理
网上找了一大堆的例子,没一个跑通的,都是copy转发,哎,整理得好辛苦..做个笔记,方便正遇到此问题的猿们能够得到帮助....废话不多说,贴代码..... 项目结构说明: 1.dao层的admin.w ...
- SpringMvc定时器任务
在最近的工作中,涉及到一个定时任务,由于以前对springMVC使用较少,所以,上网找了一点资料.这个demo感觉挺好,推荐给大家. 使用到的JAR文件: aopalliance-1.0.jarcom ...
- Springmvc 定时器的实现
有时候会需要项目中,定时去执行一些东西,这个时候就需要用到定时器了.比较简单, 当你springmvc环境搭建成功的时候. 本文转载自:https://www.cnblogs.com/wqj-blog ...
- SpringMVC + Mybatis 多数据源配置
比较常用的配置,多数据源.主从等等. 大概的逻辑是: 1.spring-mybatis.xml中配置多个数据源 2.使用Spring提供的AbstractRoutingDataSource类来根据请求 ...
- springMVC 定时器配置
1.在springMVC中加入 xmlns:task="http://www.springframework.org/schema/task" http://www.springf ...
- springmvc+mybatis多数据源配置,AOP注解动态切换数据源
springmvc与springboot没多大区别,springboot一个jar包配置几乎包含了所有springmvc,也不需要繁琐的xml配置,springmvc需要配置多种jar包,需要繁琐的x ...
- springmvc SSM 多数据源 shiro redis 后台框架 整合
A集成代码生成器 [正反双向(单表.主表.明细表.树形表,开发利器)+快速构建表单 下载地址 ; freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类 ...
- spring入门(六)【springMVC中各数据源配置】
在使用spring进行javaWeb开发的过程中,需要和数据库进行数据交换,为此要经常获取数据库连接,使用JDBC的方式获取数据库连接,使用完毕之后再释放连接,这种过程对系统资源的消耗无疑是很大的,这 ...
随机推荐
- leetcode 有效的字母异位词
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词. 示例 1: 输入: s = "anagram", t = "nagaram" ...
- 【转】.NET内存管理、垃圾回收
1. Stack和Heap 每个线程对应一个stack,线程创建的时候CLR为其创建这个stack,stack主要作用是记录函数的执行情况.值类型变量(函数的参数.局部变量 等非成员变量)都分配 ...
- Devexpress GridControl无限高度惹得祸
异常提示: issue, place the grid into a container that will give a finite height to the grid, or manually ...
- Katalon Studio简单使用(一)
官网地址:https://www.katalon.com/ katalon 目前有两种产品 一个是studio 另外一个是katalon analytics,此处先来学习studio部分. 文章学习内 ...
- 细节之strcat
写代码也这么多年了,有些非常基础的东西却让我差点栽跟头: 有如下一种场景的需求代码: char tmp; ]; memset(input, , ); ) // ptr是得到了某块全局内存的 { tmp ...
- 【题解】 AGC029-A Irreversible operation
传送门 定位:思维好题. 考虑无论如何每一个W都会和前面的B在一起交换一次,所以直接求和就好了. 注意long long的使用. #include<stdio.h> #include< ...
- web负载均衡【总结归纳所有看过的资料的理论】
web负载均衡 在有些时候进行扩展是显而易见的,比如下载服务由于带宽不足而必须进行的扩展,但是,另一些时候,很多人一看到站点性能不尽如人意,就马上实施负载均衡等扩展手段,真的需要这样做吗?当然这个问题 ...
- Django的views视图系统
老师的博客:http://www.cnblogs.com/liwenzhou/articles/8305104.html 以看老师的博客为主 一个视图函数(类),简称视图,是一个简单的Python 函 ...
- HTML防止input回车提交表单
原链接:https://blog.csdn.net/ligang2585116/article/details/44699567 自动提交情况说明: 1.默认情况下,单个输入框,无论按钮的type=& ...
- php-fpm 和 nginx 的两种通信方式
在 linux 中,nginx 服务器和 php-fpm 可以通过 tcp socket 和 unix socket 两种方式实现. 一下内容转自:https://blog.csdn.net/qq62 ...