티스토리 뷰

 

 

“서블릿 로드(loading)” 과정은 서블릿 컨테이너(Tomcat, Jetty 등)가

서블릿 클래스를 메모리에 올리고 초기화하는 전 과정을 말합니다.
즉, “클라이언트 요청을 처리하기 전에 서블릿이 어떻게 준비되는가”에 대한 과정이다.

클라이언트 요청
   ↓
웹 서버 (ex: Tomcat)
   ↓
서블릿 컨테이너
   ↓
서블릿 로드 → 인스턴스 생성 → 초기화(init)
   ↓
요청 처리(service → doGet/doPost)
   ↓
종료(destroy)

 

 


 

 

1️⃣ 서블릿 클래스 로드 (Class Loading)

  • Servlet Container가 web.xml 또는 @WebServlet 어노테이션을 보고 해당 서블릿 클래스를 식별합니다.
  • 아직 요청이 오지 않은 상태에서는 클래스를 메모리에 올리지 않을 수도 있음.
    • load-on-startup 설정이 없으면, 첫 요청이 들어올 때 로드됨 (lazy loading).
    • load-on-startup 설정이 있으면, 컨테이너가 서버 시작 시점에 미리 로드함 (eager loading).

2️⃣ 인스턴스 생성 (Instantiation)

  • 클래스가 로드되면, 컨테이너는 서블릿 객체를 1회만 생성(new) 합니다.
  • 서블릿 인스턴스는 일반적으로 싱글톤(1개만 존재) 형태로 관리됩니다.
HelloServlet servlet = new HelloServlet();

 

3️⃣ 초기화 (Initialization)

  • 인스턴스가 생성되면, 컨테이너가 init() 메서드를 호출합니다.
  • 서블릿의 초기 설정(예: DB 연결, 설정 로드 등)은 여기서 수행합니다.
  • 이 단계는 서블릿 생명주기에서 단 한 번만 호출됩니다.
public void init() throws ServletException {
    // 초기화 코드
    System.out.println("서블릿 초기화 완료");
}

 

4️⃣ 요청 처리 (Service 단계)

  • 초기화가 완료된 후 클라이언트 요청이 들어오면 컨테이너는 service() 메서드를 호출합니다.
  • HttpServlet의 경우 내부에서 자동으로 **doGet() / doPost()**로 분기됩니다.
public void service(ServletRequest req, ServletResponse res) {
    // 요청 방식(GET, POST 등)에 따라 분기
}

 

5️⃣ 종료 (Destroy)

  • 컨테이너가 종료되거나 서블릿이 언로드될 때 destroy() 호출.
  • 리소스 해제, 연결 종료 등 정리 작업을 수행합니다.
public void destroy() {
    System.out.println("서블릿 종료");
}

 

 

⚙️ 정리 요약표

단계메서드실행 시점호출 횟수

 

1 Class Loading 첫 요청 시 또는 서버 시작 시(load-on-startup 설정 시) 1회
2 Instantiation 클래스 로드 후 1회
3 init() 인스턴스 생성 직후 1회
4 service() 매 요청 시 요청마다
5 destroy() 서버 종료 또는 서블릿 제거 시 1회

 

 

서버 로그로 본다면 이런 순서로 나타납니다

[INFO] HelloServlet 클래스 로드됨
[INFO] HelloServlet 인스턴스 생성됨
[INFO] init() 호출 - 초기화 수행
[INFO] service() 호출 - 클라이언트 요청 처리
[INFO] destroy() 호출 - 종료 처리