본문 바로가기
CS/Web

웹 애플리케이션 이해 - 서블릿(Servlet)

by HwaHyun 2023. 7. 21.

서블릿(Servlet) 이란?

클라이언트의 요청을 처리하고, 그 결과를 반환하는 Servlet 클래스의 구현 규칙을 지킨 자바 웹 프로그래밍 기술 이다.

 

 

서블릿의 특징

과거 서블릿이 없는 시절에는 HTTP 데이터 통신을 위해서 개발자는 아래와 같은 프로세스를 직접 모두 구현해야 했다.

  1. 서버 TCP/IP 연결 대기, 소켓 연결
  2. HTTP 요청 메세지를 파싱해서 읽기
  3. POST 방식, /save URL 인지
  4. Content-Type 확인
  5. HTTP 메시지 바디 내용 파싱
    •  username, age 데이터를 사용할 수 있게 파싱
  6. 저장 프로세스 실행
  7. 비즈니스 로직 실행
    •  데이터베이스에 저장 요청
  8. HTTP 응답 메시지 생성 시작
    •  HTTP 시작 라인 생성
    •  Header 생성
    •  메시지 바디에 HTML 생성해서 입력
  9. TCP/IP 응답 전달, 소켓 종료

하지만, 매번 이러한 프로세스를 구현하는 것은 매우 리소스가 많이 소모되고, 비효율적이다.

그래서 이런 문제를 해결하기 위해서 서블릿이란 것이 탄생하게 되었다.

 

서블릿의 개발로, 개발자는 비즈니스 로직 실행과 데이터베이스에 저장요청 프로세스만 집중할 수 있게 되었다.

 

자바 서블릿 코드 예시)

  • urlPatterns("hello)의 URL이 호출되면 서블릿 코드가 실행
  • HTTP 요청 정보를 편리하게 사용할 수 있는 HttpServletRequest
  • HTTP 응답 정보를 편리하게 제공할 수 있는 HttpServletResponse

 

서블릿의 HTTP 요청, 응답 흐름

  1. HTTP 요청시
  2. WAS는 Request, Response 객체를 새로 만들어서 서블릿 객체 호출
  3. Request 객체에서 HTTP 요청 정보를 꺼내서 확인 및 사용
  4. Response 객체에서 HTTP 응답 정보를 입력
  5. WAS는 Response 객체에 담겨있는 내용을 바탕으로 HTTP 응답 정보를 생성 후 응답

 

서블릿 컨테이너란?

  • 톰캣과 같이 서블릿을 지원하는 WAS를 서블릿 컨테이너라고 한다.
  • 서블릿 컨테이너는 서블릿 객체를 생성, 초기화, 호출, 종료하는 생명주기를 관리
  • 서블릿 객체는 싱글톤으로 관리
  • 고객의 요청이 올 때 마다 매번 새로운 객체를 생성하는 것은 비효율
  • 최초 로딩 시점에 서블릿 객체를 미리 만들어두고 재활용
  • 모든 고객 요청은 동일한 서블릿 객체 인스턴스에 접근
  • 공유 변수 사용에 주의
  • 서블릿 컨테이너 종료시 함께 종료
  • JSP도 서블릿으로 변환 되어서 사용
  • 동시 요청을 위한 멀티 쓰레드 처리 지원