강의를 보다가 servlet를 왜 사용하는걸까? 하는 의문이 들어 정리해보게 되었다.
동적 웹 페이지를 만들 때 사용되는 자바 기반의 웹 애플리케이션 프로그래밍 기술
서블릿은 웹 요청과 응답의 흐름을 간단한 메서드 호출만으로 체계적으로 다룰 수 있게 해준다.
클라이언트가 웹 서버에 요청하면 웹 서버는 그 요청을 톰캣과 같은 WAS에 위임한다. 그러면 WAS는 각 요청에 해당하는 서블릿을 실행한다. 그리고 서블릿은 요청에 대한 기능을 수행한 후 결과를 반환하여 클라이언트에 전송한다.
* WAS : 서블릿 컨테이너(웹 컨테이너)와 Web Server의 결합
1. 클라이언트 요청
2. HttpServletRequest, HttpServletResponse 객체 생성
3. Web.xml이 어느 서블릿에 대해 요청한 것인지 탐색
4. 해당하는 서블릿에서 service() 메소드 호출
5. doGet() 또는 doPost() 호출
6. 동적 페이지 생성 후 ServletResponse 객체에 응답 전송
7. HttpServletRequest, HttpServletResponse 객체 소멸
* 서블릿 인스턴스는 소멸되지 않는다.
⇒ 싱글톤(Singleton) 패턴이라고 하며, 서블릿을 컨테이너에 담아두고 호출이 발생할 때마다 꺼내어 사용한다.
⇒ 요청이 들어올 때마다 서블릿을 정의하고, 요청 수행시 매번 스레드를 생성해 준다.
⇒ 이때, 한번에 여러 요청이 들어오면? 멀티스레드로 요청을 관리
⇒ 스레드 생성시 발생하는 오버헤드, 스레드 전환시 발생하는 context swtiching등의 문제를 야기할 수 있다.
⇒ 이때 요청을 받고, 응답을 만들고, 요청에 맞는 서블릿을 찾는 과정(Handler)이 매번 중복되며 이 공통 로직을 한 번에 처리할 수 있는 방법이 있는데, 이게 바로 Dispatcher Servlet이다.
public class FirstServlet extends HttpServlet {
@Override
public void init() {
...
}
@Override
public void doGet(HttpServletRequest req, HttpServletResponse resp) {
...
}
@Override
public void destroy() {
...
}
}
초기화 : init()
작업 수행 : doGet(), doPost()
종료 : destroy()
참고 : https://moonsbeen.tistory.com/321, https://velog.io/@falling_star3/Tomcat-서블릿Servlet이란