JavaWeb工程启动执行指定任务

有些任务需要在WEB工程启动的时候进行执行,如静态文件读取、数据库连接、初始化等,需要通过配置load-on-startup或listener相关的内容实现

所属分类 JAVA

相关标签 任务加载监听

load-on-startup属性

通过load-on-startup标签元素的配置完成初始化,Tomcat容器启动时优先加载这些类的方法。

<!-- 开放API服务入口 -->
<servlet>
    <servlet-name>AutoOpenApiServlet</servlet-name>
    <servlet-class>com.mebugs.AutoAcceptApiServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping> 
    <servlet-name>AutoOpenApiServlet</servlet-name> 
    <url-pattern>/OpenAs_API</url-pattern> 
</servlet-mapping>
<!-- 也可以这样配置 -->
<servlet>
    <servlet-name>GetAllConfigServlet</servlet-name>
    <servlet-class>com.mebugs.GetAllConfigServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
public class GetAllConfigServlet extends HttpServlet 
{
    // Servlet的init方法会在Tomcat启动的时候执行
    @Override
    public void init() throws ServletException {
        // 需要实现的相关逻辑
    }
}    

直接启动是会占用tomcat的启动时长。

为了避免启动超时,可以通过线程的方式做一些改良。

public class GetAllConfigServlet extends HttpServlet 
{
    // Servlet的init方法会在Tomcat启动的时候执行
    @Override
    public void init() throws ServletException {
         ConfThread thread = new ConfThread();
        // 使用另一个线程来执行该方法,会避免占用Tomcat的启动时间
        new Thread(thread).start();
    }
}  
public class ConfThread implements Runnable {
    // Tomcat启动结束后执行
    @Override
    public void run() 
    {    
        //需要实现的相关逻辑
    }
}
  1. 没有配置 load-on-startup 标签元素,则默认不自动加载
  2. 配置后,容器在启动的时候就加载这个servlet**(实例化并调用其init()方法)**
  3. 元素的值必须是一个整数,表示servlet应该被载入的顺序
  4. 元素的值为0或者大于0时,表示容器在应用启动时就加载并初始化这个servlet
  5. 元素的值小于0或者没有指定时,则表示容器在该 servlet 被选择时才会去加载(默认场景)
  6. 元素的值正数的值越小,该 servlet 的优先级越高,应用启动时就越先加载
  7. 元素的值相同时,容器就会自己选择顺序来加载

因此,<load-on-startup>n</load-on-startup>中n的取值1、2、3、4、5代表的是优先级,而非启动延迟时间。

listener 监听器

我们都知道 Servlet 可以通过配置 load-on-startup 实现工程启动自动加载,也归纳过 web.xml 中各类标签元素的加载顺序。

分析可知 listener 监听器在启动时也会自动加载。

通过 listener 监听器启动初始化参数

<!-- 全部参数初始化 -->
<listener>
  <listener-class>com.net.sobest.GetAllConfigListener</listener-class>
</listener>
public class GetAllConfigListener implements ServletContextListener 
{
    public GetAllConfigListener() {}
    

    public void contextDestroyed(ServletContextEvent arg0) {}
    
    //初始化方法
    public void contextInitialized(ServletContextEvent arg0) 
    {
        try 
        {
            //需要实现的相关逻辑
        } 
        catch (Exception e) 
        {
            //异常处理
        }
    }
}

Spring框架的ApplicationListener,感兴趣的小伙伴可以自行度量。

米虫

做一个有理想的米虫,伪全栈程序猿,乐观主义者,坚信一切都是最好的安排!

本站由个人原创、收集或整理,如涉及侵权请联系删除

本站内容支持转发,希望贵方携带转载信息和原文链接

本站具有时效性,不提供有效、可用和准确等相关保证

本站不提供免费技术支持,暂不推荐您使用案例商业化

发表观点

提示

昵称

邮箱

QQ

网址

当前还没有观点发布,欢迎您留下足迹!

同类其他

JAVA

Spring、SpringMVC和SpringBoot

Spring就像一个大家族,里面包含了很多衍生产品,其中最为出名的就是SpringMVC和SpringBoot,那么这三者之间是什么关系呢?SpringMVC和SpringBoot又专门用来做什么呢?

自定义filter过滤器拦截未登录(非法)请求

在JAVA的WEB工程中我们可以将JSP页面文件放在WEB-INFO中限制用户进行URL直接访问,但静态资源如js、css文件却是需要被外部直接访问的,直接对外暴露又不太安全,可以通过自定义过滤器处理

一文理解SpringMVC框架核心

SpringMVC框架是围绕DispatcherServlet(前端控制器)展开的,本文描述SpringMVC的优点、各个核心类(角色)作用,并说明用户请求数据到最终视图返回完整的数据传输过程

SpringBoot配置druid(德鲁伊)数据库连接池

SpringBoot 的 MyBatis 默认采用 hikari 连接池,druid (德鲁伊) 连接池由阿里开源,它不仅仅是一个连接池,更是代理、过滤器、解析器、插件、监控、优化等实用功能组件库,更在阿里生产环境得到验证,所以 Lets Do It

Struts2 + Spring框架融合配置

Struts2框架以WebWork优秀的设计思想为核心,吸收了 Struts框架的部分优点,提供了一个更加整洁的MVC设计模式实现的Web应用程序框架,本文主要是与Spring整合关键配置和实例

Maven的pom配置文件的scope属性

scope属性主要用于控制依赖范围,主要分为编译、打包、运行、测试、依赖传递等各个常见,scope不同于optional提供了更多可选择的配置参数用于应对不同的依赖场景。

选择个人头像

昵称

邮箱

QQ

网址

评论提示

  • 头像:系统为您提供了12个头像自由选择,初次打开随机为你选择一个
  • 邮箱:可选提交邮箱,该信息不会外泄,或将上线管理员回复邮件通知
  • 网址:可选提交网址,评论区该地址将以外链的形式展示在您的昵称上
  • 记忆:浏览器将记忆您已选择或填写过得信息,下次评论无需重复输入
  • 审核:提供一个和谐友善的评论环境,本站所有评论需要经过人工审核