项目需求:将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>