码迷,mamicode.com
首页 > 编程语言 > 详细

利用多线程解决多事务不同定时区间歇触发问题的一种方法

时间:2015-05-10 23:58:49      阅读:300      评论:0      收藏:0      [点我收藏+]

标签:

1.背景

项目中需要解决一个这样的问题:有两个事务均需要每隔几秒触发一次,但是两个事务都只是在规定的时间区域内才进行该行为。比如,在早上八点到晚上六点为上班时间,在这个时间段内两个事务必须每隔几秒被执行一次,下班后则停止工作。

2.思路

这个问题最开始我是想利用timer来解决,即做两个timer,一个timer来控制一个事务,然后在各事务对应时间区域内执行。

但是考虑到Timer是在主线程里执行的,Thread 是在自己的线程中执行的,在多核多线程的 CPU 中,利用Thread的效率高更高一些。而且后期事务变多,控制更复杂,用timer也不是很利于扩展。所以最后决定使用多线程来解决该问题。

经过思考以及参阅类似案例,比如http://www.cnblogs.com/shuang121/archive/2012/07/05/2578033.html,最后将框架设计成如下结构:

     技术分享                  

3.具体实现

3.1 IshedulerJob

 技术分享

3.2 Job

 技术分享

3.3SchedulerConfiguration

 技术分享

3.4Scheduler

 技术分享

3.5 viewer

 技术分享

4. 优化

a.两个事务均涉及到数据库的多数据增删查改,为了保证数据的唯一性,对数据库操作均采取事务型操作。

 技术分享

b.为了避免数据库的重复连接和关闭,这里尽量使用数据库的长连接。同时,为了避免两个事务共用一个数据库连接而出现的问题,特地使用简单的数据库连接池进行处理。

 技术分享

c.为了连接池能被共享,对连接池所在类进行单利模式。

 技术分享

 

利用多线程解决多事务不同定时区间歇触发问题的一种方法

标签:

原文地址:http://www.cnblogs.com/naaoveGIS/p/4493334.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!