서블릿이라고 하면 " 클라이언트의 요청을 처리하고, 그 결과를 반환하는 servlet 클래스의 구현 규칙을 지킨 자바 웹 프로그래밍 기술" 이다.
간단히 말하자면, 자바를 사용하여 웹을 만들기 위해 필요한 기술이다.
ex) 로그일을 할때, 서버는 아이디,비밀번호를 확인 후, 다음 페이지를 띄워주는데 이 역할을 하는 것이 서블릿이다.
- 클라이언트의 요청에 대해 동적으로 작동하는 웹어플리케이션 컴포넌트
- html을 사용해 요청에 응답함.
- java thread를 이용해 동작함.
- MVC패턴에서 Controller로 이용함.
일반적으로 웹서버는 정적인 페이지만을 제공한다. 그렇기에 동적 페이지를 제공하기 위해 웹서버는 다른 곳에 도움을 요청해 동적인 페이지를 작성해야 함.
웹서버가 동적인 페이지를 도와줄 수 있도록 도와주는 어플리케이션이 서블릿임.
- 클라이언트가 url을 입력하면 HTTP Request가 서블릿 Controller로 전송을 함.
- 요청을 받은 서블릿 Controller는 HttpServletRequest,Response 객체를 생성함.
- web.wml을 기반을 통해 클라이언트가 요청한 url이 어느 서블릿 메소드에 대한 요청인지 서치한다.
- 해당 서블릿에서 클라이언트의 GET,POST여부에 따라 doGet(),doPost()를 호출한다.
- doGet(),doPost()메소드는 동적페이지를 생성한 후 httpservletresponse 객체에 응답을 보낸다.
- 응답이 끝나면 httpservletresponse,request를 없앤다.
서블릿 컨테이너는 서블릿을 관리해주는 것입니다. 클라이언트의 요청을 받아주고, 응답할 수 있게, 웹서버와 소켓을 통신한다. 이에 대표적인 예가 톰캣!
= 서블릿을 실행하고, HTTP 요청과 응답을 처리하는 등 전체적인 실행 환경을 제공하는 책임한다.
- 웹서버와의 통신 지원.
- 서블릿 컨테이너는 서블릿, 웹서버가 손쉡게 통신할 수 있게 해준다. 일반적으로는 소켓을 만들고 막 해야하는데, 이러한 기능을 서블릿 컨테이너는 제공해주기 때문에, 쉽게 가능하다.
- 서블릿의 생명주기 관리
- 서블릿 컨테이너는 서블릿의 탄생과 사망을 관리해준다.
- 멀티쓰레드 지원 및 관리
- 서블릿 컨테이너는 요청이 올 때마다 새로운 자바 쓰레드를 하나 생성하는데, HTTP 서비스 메소드를 실행하고 나면 쓰레드는 자동으로 죽게된다. 서버가 다중 쓰레드를 생성 및 운영해주니 안전하다.
- 클라이언트의 요청이 들어오면 컨테이너는 해당 서블릿이 메모리에 있는지 체크하고, 없을 시 init()메소드를 호출하여 적재합니다. init()메소드는 처음 한번만 실행되기에, 서블릿의 쓰레드에서 공통적으로 사용해야하는 것이 있다면 오버라이딩하여 구현하면 된다. 실행 중 서블릿이 변경되었을 경우, 기존 서블릿을 파괴하고 init()을 통해 새로운 내용을 메모리에 적재한다.
- init()이 호출된 후. 클라이언트의 요청에 따라 응답이 doGet,doPost로 분기된다. 이떄 서블릿 컨테이너가 요청이 오면 가장 먼저 처리하는 과정으로 생긴 HttpServletRequest, HttpServletResponse에 의해 request와 response객체가 제공된다.
- HttpServletRequest, HttpServletResponse에 의해 request와 response객체가 제공된다.
서블릿 컨테이너는 서블릿들이 공통적으로 참조할 수 있는 오브젝트를 하나 생성하는데 이름 서블릿 컨텍스트라고 한다. 개발자가 구현한 서블릿들을 모은 하나의 프로젝트를 웹서블릿 컨테이너인 톰켓에 배포를할 시, 톰캣은 web.xml 파일을 참고하여 서블릿 컨텍스트를 생성한다.(배포한 프로젝트로 생성되는 하나의 인스턴트 당 한개) 서블릿 컨텍스트는 다양한 데이터를 저장할 수 있는데, ex) 톰캣에서 JSP페이지를 내려줄 때, 모든 서블릿(페이지)에서 공통적으로 사용되는 정보 등을 서블릿들이 공통적으로 접근해 참조할 수 있는 정보들을 저장할 수 있다.
서블릿은 자바 소스코드 속 html이 들어가는 형태인데, jsp는 html 소드코드 속에 자바 소브코드가 들어가는 구조이다.
서블릿은 꽤 복잡하기에 JSP가 나왔는데, JSP는 WAS에 의해 서블릿 클래스로 변환하여 사용되어진다.
웹 서버가 사용자로부터 서블릿에 대한 요청을 받으면 서블릿컨테이너에 그 요청을 넘깁니다. 요청을 받은 컨테이너는 HTTP Request와 HTTP Response 객체를 만들어, 이들을 통해 서블릿 doPost()나 doGet()메소드 중 하나를 호출합니다. 만약 서블릿만 사용하여 사용자가 요청한 웹 페이지를 보여주려면 out 객체의 println 메소드를 사용하여 HTML 문서를 작성해야 하는데 이는 추가/수정을 어렵게 하고, 가독성도 떨어지기 때문에 JSP를 사용하여 비지니스 로직과 프레젠테이션 로직을 분리합니다. 여기서 서블릿은 데이터의 입력, 수정 등에 대한 제어를 JSP에게 넘겨서 프레젠테이션 로직을 수행한 후 컨테이너에게 Response를 전달합니다. 이렇게 만들어진 결과물은 사용자가 해당 페이지를 요청하면 컴파일이 되어 자바파일을 통해 .class 파일이 만들어지고, 두 로직이 결합되어 클래스화 되는것을 확인할 수 있다. 즉, out객체의 println 메소드를 사용해서 구현해야하는 번거로움을 JSP가 대신 수행해줍니다
출처:
https://mangkyu.tistory.com/14 [MangKyu's Diary:티스토리]
https://rura6502.tistory.com/entry/Servlet-Servlet-Container-Spring-Container