最近在一个电子商务项目我遇到了一些问题,就是处理大数据初始化。因为刚开始设计的是把大数据量的初始化放入到index.do,但是这里面就有一个很大的问题,就是别人访问我的首页时候由于第一次请求数据量就可能造成用户访问超时。所以一超时用户就会关闭浏览器,这时候会造成抛出异常,异常的数据是:broken pipe。
于是这样就造成网站访问异常缓慢,而且有的事情请求量过大了会直接造成504错误,于是我想了一下决定让大数据量在tomcat启动的时候去进行初始化,于是我自己写了一个StartupListener该类继承于ServletContextListener,这个接口提供了两个接口:一个是init()在tomcat启动的时候调用,而另一个destory()方法则是在tomcat销毁时调用。话也不多说了,我把代码与配置亮出来,方便以后遇到同样的问题时候我能够借用这个东西。
而xml的配置我是这么配置的:
于是这样就造成网站访问异常缓慢,而且有的事情请求量过大了会直接造成504错误,于是我想了一下决定让大数据量在tomcat启动的时候去进行初始化,于是我自己写了一个StartupListener该类继承于ServletContextListener,这个接口提供了两个接口:一个是init()在tomcat启动的时候调用,而另一个destory()方法则是在tomcat销毁时调用。话也不多说了,我把代码与配置亮出来,方便以后遇到同样的问题时候我能够借用这个东西。
package com.noah.tomcat;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import com.noah.ebiz.cache.Cache;
import com.noah.ebiz.commodity.LuceneSearch;
public class StartupListener implements ServletContextListener {
@Override
public void contextDestroyed(ServletContextEvent arg0) {
// TODO Auto-generated method stub
}
@Override
public void contextInitialized(ServletContextEvent arg0) {
System.out.println("数据初始化.......");
Cache cache = Cache.getInstance();
LuceneSearch search = LuceneSearch.getInstace();
System.out.println("数据化初始化结束.......");
}
}
而xml的配置我是这么配置的:
<listener>
<listener-class>com.noah.tomcat.StartupListener</listener-class>
</listener>