클라이언트의 요청을 처리하고, 그 결과를 반환하는
Servlet 클래스의 구현 규칙을 지킨 자바 웹 프로그래밍 기술
자바 서블릿(Java Servlet)은 자바를 사용하여 웹페이지를 동적으로 생성하는 서버측 프로그램 혹은 그 사양을 말하며, 흔히 "서블릿"이라 불린다.
간단히 말해서, 서블릿이란 자바를 사용하여 웹을 만들기 위해 필요한 기술입니다.
클라이언트가 어떠한 요청을 하면 그에 대한 결과를 다시 전송해주어야 하는데, 이러한 역할을 하는 자바 프로그램입니다.
웹을 만들때는 다양한 요청(Request)과 응답(Response)이 있기 마련이고 이 요청과 응답에는 규칙이 존재합니다. 이러한 요청과 응답을 일일이 처리하려면 많이 힘들껍니다.
서블릿은 이러한 웹 요청과 응답의 흐름을 간단한 메서드 호출만으로 다룰 수 있게 해주는 기술입니다.
서블릿을 사용하지 않고 직접 HTTP 통신으로 오고가는 문자열을 파싱하여 서블릿과 같은 기능을 구현해도 무방하지만, 이미 편리하게 사용할 수 있는 서블릿을 놔두고 직접 문자열 파싱을 구현하는 것은 개발자가 온전히 비즈니스 로직에 집중하지 못하게 만들 수 있다.
우리는 서블릿을 통해 문자열 파싱 등에 열올리지 않고 비즈니스 로직에 더욱 집중할 수 있다.
직접 만들면 비즈니스 로직을 짜기 전에 수 많은 규약과 문자열 검증에 정신이 나가버릴 수 있다.
서블릿(Servlet)의 주요 특징 정리
개발자가 자바 서블릿 소스코드(.java)를 작성한다. (위에서는 스프링 프레임워크를 이용해 작성)
해당 자바 서블릿 소스가 빌드시 컴파일되며 서블릿 클래스(.class)가 된다.
해당 자바 서블릿 클래스가 톰캣과 같은 서블릿 컨테이너에 등록된다.
클라이언트가 특정 경로에 대한 HTTP Request를 보낸다.
HTTP Request에 상응하는 서블릿이 실행된다.
서블릿 메소드(비즈니스 로직)가 실행된다.
DB 연동 작업이 있는 경우 DB 연동이 되어 데이터를 CRUD한다.
완성된 데이터를 클라이언트에게 반환해준다.
서블릿 컨테이너
서블릿들의 생성, 실행, 파괴를 담당한다.
서블릿들을 위한 상자(Container)입니다.
서블릿 컨테이너는 구현되어 있는 servlet 클래스의 규칙에 맞게 서블릿은 관리해주며 클라이언트에서 요청을 하면 컨테이너는 HttpServletRequest, HttpServletResponse 두 객체를 생성하며 GET,POST여부에 따라 동적인 페이지를 생성하여 응답을 보냅니다.
클라이언트의 요청(Request)을 받아주고 응답(Response)할 수 있게, 웹서버와 소켓으로 통신하며 대표적인 예로 톰캣(Tomcat)이 있습니다. 톰캣은 실제로 웹 서버와 통신하여 JSP(자바 서버 페이지)와 Servlet이 작동하는 환경을 제공해줍니다.
1. 웹서버와의 통신 지원
서블릿 컨테이너는 서블릿과 웹서버가 손쉽게 통신할 수 있게 해줍니다. 일반적으로 우리는 소켓을 만들고 listen,
accept 등을 해야하지만 서블릿 컨테이너는 이러한 기능을 API로 제공하여 복잡한 과정을 생략할 수 있게 해줍니다.
그래서 개발자가 서블릿에 구현해야 할 비지니스 로직에 대해서만 초점을 두게끔 도와줍니다.
2. 서블릿 생명주기(Life Cycle) 관리
서블릿 컨테이너는 서블릿의 탄생과 죽음을 관리합니다. 서블릿 클래스를 로딩하여 인스턴스화하고,
초기화 메소드를 호출하고, 요청이 들어오면 적절한 서블릿 메소드를 호출합니다.
또한 서블릿이 생명을 다 한 순간에는 적절하게 Garbage Collection(가비지 컬렉션)을 진행하여 편의를 제공합니다.
3. 멀티쓰레드 지원 및 관리
서블릿 컨테이너는 요청이 올 때 마다 새로운 자바 쓰레드를 하나 생성하는데, HTTP 서비스 메소드를
실행하고 나면, 쓰레드는 자동으로 죽게됩니다. 원래는 쓰레드를 관리해야 하지만 서버가 다중 쓰레드를
생성 및 운영해주니 쓰레드의 안정성에 대해서 걱정하지 않아도 됩니다.
4. 선언적인 보안 관리
서블릿 컨테이너를 사용하면 개발자는 보안에 관련된 내용을 서블릿 또는 자바 클래스에 구현해 놓지 않아도 됩니다.
일반적으로 보안관리는 XML 배포 서술자에 다가 기록하므로, 보안에 대해 수정할 일이 생겨도 자바 소스 코드를
수정하여 다시 컴파일 하지 않아도 보안관리가 가능합니다.
서블릿 컨테이너가 흐름을 제어한다. 즉 IoC(Inversion of Control)가 일어난다.
Servlet Request, Servlet Response 객체를 생성합니다.
설정 파일을 참고하여 매핑할 Servlet을 확인합니다.
해당 서블릿 인스턴스 존재의 유무를 확인하여 없으면 init() 메소드(한번만 실행됨)를 호출하여 생성합니다.
Servlet Container에 스레드를 생성하고 service를 실행합니다.
응답을 처리하였으면 distory() 메소드를 실행하여(한번만 실행됨) Servlet Request, Servlet Response 객체를 소멸합니다. 서블릿 소멸 시 Garbage Collection(가비지 컬렉션)이 진행됩니다.