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() → 垃圾回收
相关推荐
juniperhan17 小时前
Flink 系列第25篇:Flink SQL 集成 Hive 实践:流批一体下的实时数仓利器
大数据·数据仓库·hive·分布式·sql·flink
Irene199118 小时前
Sqoop 安装完整教程(基于 WSL2 + Ubuntu 24.04)
hadoop·ubuntu·sqoop
r-t-H2 天前
从零开始搭建CDH-第十二章
linux·hive·spark·centos·hbase
m0_639310792 天前
大数据技术原理-HDFS的安装与应用
java·大数据·jvm·hadoop·spring·hdfs·eclipse
188105069632 天前
摸鱼事务所——团队作业——大模型评测作业
大数据·hadoop·分布式
我思故我在78962 天前
hdfs文件系统
大数据·hadoop·hdfs
大连赵哥2 天前
分布式文件存储系统:Hadoop HDFS
hadoop·分布式·hdfs
王小王-1232 天前
基于Hadoop的服装电商数据分析系统【Hdfs、flume、HIve、sqoop、MySQL、echarts】
hive·hadoop·hdfs·服装电商分析·服装大数据
青春万岁!!3 天前
hiveSQL脚本性能优化-减少表扫描
大数据·hive·sql
阿坤带你走近大数据4 天前
Hadoop中的MapReduce介绍
大数据·hadoop·mapreduce