Servlet的生命周期

Servlet的生命周期阶段

Servlet的生命周期由Servlet容器(如Tomcat)管理,主要分为以下阶段:

  1. 加载和实例化

    容器通过类加载器加载Servlet类,并调用无参构造函数创建Servlet实例。通常发生在首次请求时或容器启动时(通过<load-on-startup>配置)。

  2. 初始化(init)

    调用init(ServletConfig config)方法,完成一次性初始化操作(如加载资源)。该方法仅在生命周期内执行一次。若初始化失败,容器会卸载Servlet。

  3. 服务处理(service)

    对于每个请求,容器调用service()方法,并根据请求类型(GET/POST等)分发给doGet()doPost()等具体方法。Servlet可同时处理多个请求(需注意线程安全)。

  4. 销毁(destroy)

    容器在卸载Servlet前调用destroy()方法,释放资源(如关闭数据库连接)。调用后实例被标记为垃圾回收。

关键方法说明

  • init(ServletConfig config)

    接收容器提供的配置参数(如web.xml中的<init-param>),可通过getServletConfig()获取。

  • service(HttpServletRequest req, HttpServletResponse res)

    默认实现将请求分发给对应的doXxx()方法。通常无需重写。

  • destroy()

    确保在方法内完成资源清理,避免内存泄漏。

线程安全注意事项

  • Servlet实例默认是单例多线程的,避免在service()doXxx()中使用实例变量。
  • 如需共享数据,使用同步块或线程安全集合(如ConcurrentHashMap)。

配置示例(web.xml)

XML 复制代码
<servlet>
    <servlet-name>ExampleServlet</servlet-name>
    <servlet-class>com.example.ExampleServlet</servlet-class>
    <load-on-startup>1</load-on-startup>  <!-- 启动时初始化 -->
    <init-param>
        <param-name>config</param-name>
        <param-value>value</param-value>
    </init-param>
</servlet>

生命周期图示

复制代码
加载 → 实例化 → init() → (多次service()) → destroy() → 垃圾回收
相关推荐
vx_Biye_Design5 小时前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
lang2015092816 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
TTBIGDATA1 天前
【Atlas】Atlas Hook 消费 Kafka 报错:GroupAuthorizationException
hadoop·分布式·kafka·ambari·hdp·linq·ranger
零一科技1 天前
centos7安装hadoop3(上)
hadoop
Francek Chen1 天前
【大数据基础】实验1:熟悉常用的Linux操作和Hadoop操作
大数据·linux·hadoop·hdfs
零一科技1 天前
centos7安装hadoop3(下)
hadoop
铅笔侠_小龙虾1 天前
Flutter 组件层级关系
前端·flutter·servlet
佐伊231 天前
SQL优化剧场:当Hive/MaxCompute遇上数据倾斜的十二种剧情
hive·sql优化·maxcompute·数据倾斜
B站计算机毕业设计超人1 天前
计算机毕业设计hadoop+spark+hive共享单车预测系统 共享单车数据可视化分析 大数据毕业设计(源码+LW文档+PPT+讲解)
大数据·hadoop·python·深度学习·spark·毕业设计·课程设计
B站计算机毕业设计超人1 天前
计算机毕业设计Python+Spark+Hadoop+Hive微博舆情分析 微博情感分析可视化 大数据毕业设计(源码+LW文档+PPT+讲解)
大数据·hadoop·爬虫·python·spark·cnn·课程设计