web启动后台线程定时执行

项目需求:将Sqlserver2008R2中数据按照规则导入到Oracle。(数据持续增长)

项目现状:已有一web app将oracle数据库主键做了缓存。如果在web app启动的情况下,不能直接操作数据库,否则报主键冲突。

解决办法:启动web app时,后台新加一线程运行数据抓取代码。

1.在web.xml文件中新加一个监听,在启动后执行该监听。

web.xml

<listener> 
    <listener-class>dataExtract.web.DataExtract</listener-class> 
</listener> 

2.监听的class需实现ServletContextListener接口,具体代码如下:
DataExtract.java

public class DataExtract implements ServletContextListener
{
 public void contextDestroyed(ServletContextEvent arg0) {
  // TODO Auto-generated method stub
  
 }
//初始化
 public void contextInitialized(ServletContextEvent arg0) {
 }
}

ServletContextListener 是 ServletContext 的监听者,如果 ServletContext 发生变化,如服务器启动时 ServletContext 被创建,服务器关闭时 ServletContext 将要被销毁。
在服务器启动时,contextInitialized()方法被调用,我把它理解为main方法。

服务器将要关闭时,ServletContextListener 的 contextDestroyed()方法被调用,我这里暂时不做任何处理。

因为需要定时去取数据,所以DataExtract还得继承TimerTask类。继承该类后代码如下:

<p>public class DataExtract extends TimerTask implements ServletContextListener</p><p>{</p><p> public void contextDestroyed(ServletContextEvent arg0) {
  // TODO Auto-generated method stub
  
 }</p><p> //初始化程序
</p><p> public void contextInitialized(ServletContextEvent arg0) {</p><p>  Timer timer = new Timer() ;         
  timer.schedule(new DataExtract(), new Date(System.currentTimeMillis())) ;
 }</p><p> @Override
 public void run() 
 {</p><p>  //调用数据抓取方法
  DataInfoAction data = new DataInfoAction();
  try {
   data.init();
  } catch (Exception e) 
  {
   e.printStackTrace();
  }</p><p>  //程序每隔20秒执行一次
  Timer timer = new Timer() ;         
  timer.schedule(new DataExtract(), new Date(System.currentTimeMillis()+20000)) ;
 }
}</p>

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值