서블릿의 정의
: 클라이언트의 요청을 처리하고 그 결과를 반환하는 기술
- 동적 웹페이지 서버에서 수행되는 소형 프로그램 입니다.
- 각 사용자의 요청이 서버의 하나의 스레드로 수행됩니다. '자바 서블릿'은 자바를 사용해 웹 페이지를 동적으로 생성하는 서버내 프로그램이라고 합니다.
- JSP와 달리 자바코드 안에 HTMl을 포함하고 있다는 점이 다릅니다.
(JSP는 Html에 자바 코드 포함)
- 외부 요청에 대해 스레드로 응답하기 때문에 프로세스로 응답하는 경우보다 가볍습니다.
- java로 개발되어 다양한 플랫폼에서의 동작이 가능합니다.
ex 로그인 페이지
- Http Request에 사용자의 Id/Password가 들어간다면
- Http Response로는 로그인 후 페이지를 보내야 하니다.
- 사용자의 로그인 정보를 받아 확인후, 다음 페이지를 보내는 프로그램이 바로 서블릿 입니다.
- 웹서버는 요청을 WAS(웹 어플리케이션서버)에게 넘기고, WAS는 요청에 따른 서블릿을 실행합니다. 서블릿은 요청에 대한 응답을 클라이언트에게 보냅니다.
서블릿의 특징
- 웹 서버가 동적인 페이지를 제공할 수 있도록 돕는다.
- html을 사용하여 요청에 응답한다.
- Java Thread를 이용하여 동작한다.
- MVC 패턴에서 Controller로 이용된다.
- HTTP 프로토콜 서비스를 지원하는 javax.servlet.http.HttpServlet 클래스를 상속받는다.
- UDP보다 처리 속도가 느리다.
- HTML 변경 시 Servlet을 재컴파일해야 하는 단점이 있다.
- 서블릿은 서블릿 컨테이너에서 관리된다.(new 로 생성되지 않으며, main()이 없다)
- 사용자(클라이언트)가 URL을 입력하면 HTTP Request가 Servlet Container로 전송합니다.
- 요청을 전송받은 Servlet Container는 HttpServletRequest, HttpServletResponse 객체를 생성합니다.
- web.xml을 기반으로 사용자가 요청한 URL이 어느 서블릿에 대한 요청인지 찾습니다.
- 해당 서블릿에서 service메소드를 호출한 후 클리아언트의 GET, POST여부에 따라 doGet() 또는 doPost()를 호출합니다.
- doGet() or doPost() 메소드는 동적 페이지를 생성한 후 HttpServletResponse객체에 응답을 보냅니다.
- 응답이 끝나면 HttpServletRequest, HttpServletResponse 두 객체를 소멸시킵니다.
서블릿 컨테이너란?
우리가 서버에 서블릿을 만들게 되면 서블릿을 관리해주는 서블릿 컨테이너가 필요합니다.
예를 들어, 서블릿이 어떠한 역할을 수행하는 manual라고 보면, 서블릿 컨테이너는 그 정의서를 보고 handling한다고 볼 수 있습니다.
서블릿 컨테이너는 클라이언트의 요청(Request)을 받아주고 응답(Response)할 수 있게, 웹서버와 소켓으로 통신하며 대표적인 예로 아파치 톰캣(Tomcat)이 있습니다.
톰캣은 실제로 웹 서버와 통신하여 JSP(자바 서버 페이지)와 Servlet이 작동하는 환경을 제공해줍니다.
서블릿 컨테이너가 하는 일
- 앞서 클라이언트의 요청이 들어오면 서블릿 컨테이너는 해당 web.xml을 기반으로 사용자가 요청한 URL이 어느 서블릿에 대한 요청인지 찾습니다.
해당 서블릿이 메모리에 없을 경우 init()을 통해 생성하고, 서블릿이 변경되었을 경우 파괴 후 init()을 통해 새로운 내용을 적재합니다.
- 서블릿이 있는 경우 service() 메소드를 통해 요청에 대한 응답이 doGet(), doPost()로 나뉘어 response가 생성됩니다.
- 컨테이너가 서블릿을 종료시킬때에는 destroy()를 통해 종료됩니다.
1. 웹서버와의 통신 지원
서블릿 컨테이너는 서블릿과 웹서버가 손쉽게 통신할 수 있게 해줍니다.
- 네트워크를 통한 소통을 위해서는 소켓을 만들고 listen, accept, connect 등을 해야하지만 서블릿 컨테이너는 이러한 기능을 API로 제공하여 간편화합니다.
결과적으로 개발자는 서블릿에 구현해야 할 비지니스 로직에 대해서만 초점을 두게끔 도와줍니다.
2. 서블릿 생명주기(Life Cycle) 관리
- 서블릿 컨테이너는 서블릿의 탄생과 죽음을 관리합니다.
- 서블릿 클래스를 로딩하여 인스턴스화하고,
초기화 메소드를 호출하고, 요청이 들어오면 적절한 서블릿 메소드를 호출합니다.
- 또한 서블릿이 생명을 다 한 순간에는 적절하게 Garbage Collection(가비지 컬렉션)을 진행하여 편의를 제공합니다.
3. 멀티쓰레드 지원 및 관리
- 서블릿 컨테이너는 요청이 올 때 마다 새로운 자바 쓰레드를 하나 생성합니다.
- HTTP 서비스 메소드를 실행하고 나면, 쓰레드는 자동으로 죽게됩니다. 서버가 다중 쓰레드를 생성 및 운영해주니 쓰레드의 안정성에 대해서 걱정하지 않아도 됩니다.
4. 선언적인 보안 관리
- 서블릿 컨테이너를 사용하면 개발자는 보안에 관련된 내용을 서블릿 또는 자바 클래스에 구현해 놓지 않아도 됩니다.
- 일반적으로 보안관리는 XML 배포 서술자가 기록하므로, 보안에 대해 수정할 일이 생겨도 자바 소스 코드를 수정하여 다시 컴파일 하지 않아도 보안관리가 가능합니다.
JSP 동작구조
- 웹 서버가 사용자로부터 서블릿에 대한 요청을 받으면 서블릿컨테이너에 그 요청을 넘깁니다.
- 요청을 받은 컨테이너는 HTTP Request와 HTTP Response 객체를 만들어, 이들을 통해 서블릿 doPost()나 doGet()메소드 중 하나를 호출합니다.
- view를 위해 서블릿만 사용하게 된다면 out 객체의 println 메소드를 사용하여 HTML 문서를 작성해야 하는데 이는 추가/수정을 어렵게 하고, 가독성도 떨어지기 때문에 JSP를 사용하여 비지니스 로직과 프레젠테이션 로직을 분리합니다.
- 여기서 서블릿은 데이터의 입력, 수정 등에 대한 제어를 JSP에게 넘겨서 프레젠테이션 로직을 수행한 후 컨테이너에게 Response를 전달합니다.
즉, out객체의 println 메소드를 사용해서 구현해야하는 번거로움을 JSP가 대신 수행해줍니다
-> 비지니스, 프레젠테이션 layer... 스프링 웹 계층이 궁금하다면
스프링 웹계층
출처
https://velog.io/@xnfxnf97/JSP%EB%8F%99%EC%A0%81%EC%A0%95%EC%A0%81-%EC%9B%B9%ED%8E%98%EC%9D%B4%EC%A7%80-%EC%84%9C%EB%B8%94%EB%A6%BF-JSP
https://mangkyu.tistory.com/14