인프런 커뮤니티 질문&답변

newh08님의 프로필 이미지
newh08

작성한 질문수

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

프론트 컨트롤러 도입 - v1

FrontController 도입에 따른 Servlet Container 에 담길 객체

해결된 질문

작성

·

353

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
안녕하세요, 프론트컨트롤러를 도입하게 되면서 Servlet Container에는 어떤것이 담기게되는지 의문이 들어 질문을 남깁니다.

기존 ServletMVC 패턴을 사용할 때는 각 URL 마다 Servlet을 구현하면서, 구현한 Servlet들이 Servlet Container에 싱글톤 패턴으로 담기고, 쓰레드들이 사용하는 것 으로 이해했습니다.

그런데 FrontController를 도입하게 되면서 각 URL 에 맵핑되던 Servlet들이 전부 Controller로 변하게 되고, FrontController만 Servlet으로 남게된 것으로 이해했는데 이게 맞는 설명일까요..?

또 Controller로 변하게된 컨트롤러들은 @Controller 어노테이션을 통해 스프링 빈으로 관리되는 것으로 이해했는데, 이러면 Servlet Container 에는 FrontController를 구현한 Dispatcherservlet 만 들어있고 나머지 Controller는 스프링 컨테이너에 들어가는게 맞을까요?


처음 접하는 개념이어서 뒤죽박죽 섞인 것 같은데,, 답변 주시면 감사하겠습니다!

답변 2

2

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. newh08님

질문별로 쪼개서 답을 드릴께요.

 

Q: 기존 ServletMVC 패턴을 사용할 때는 각 URL 마다 Servlet을 구현하면서, 구현한 Servlet들이 Servlet Container에 싱글톤 패턴으로 담기고, 쓰레드들이 사용하는 것 으로 이해했습니다.

그런데 FrontController를 도입하게 되면서 각 URL 에 맵핑되던 Servlet들이 전부 Controller로 변하게 되고, FrontController만 Servlet으로 남게된 것으로 이해했는데 이게 맞는 설명일까요..?

A: 네 맞습니다. 서블릿은 이제 최초 진입 통로 역할만 하고, 실제로 동작하는 것은 컨트롤러가 담당 업무를 맞게 됩니다.

 

Q: 또 Controller로 변하게된 컨트롤러들은 @Controller 어노테이션을 통해 스프링 빈으로 관리되는 것으로 이해했는데, 이러면 Servlet Container 에는 FrontController를 구현한 Dispatcherservlet 만 들어있고 나머지 Controller는 스프링 컨테이너에 들어가는게 맞을까요?

A: 네 맞습니다^^ 참고로 과거에는 서블릿을 직접 사용했는데요. 서블릿 기능의 한계도 있고, 불편해서 지금은 스프링 컨트롤러라는 더 많은 기능을 제공하는 것을 사용한다고 이해하시면 됩니다.

감사합니다.

newh08님의 프로필 이미지
newh08
질문자

답변 감사합니다!!! 제가 잘 이해하고 있는게 맞았군요!
강의를 계속 듣다보니 서블릿 컨테이너가 단순 서블릿 인스턴스를 저장하는 역할 말고도 DispatcherServlet 이 동작하기 위한 여러 부가 기능을 가지고 있는 것 같네요..! 계속 공부해보겠습니다!

0

안녕하세요, 인프런 AI 인턴이에요.

FrontController를 도입하게 되면 각 URL에 매핑되던 Servlet들이 전부 FrontController에게 요청을 전달하게 됩니다. FrontController에서는 요청에 대한 로직 처리 후 이에 맞게 적절한 View로 전달하게 되는데, 이를 위해 다양한 객체를 Servlet Container에 담을 수 있습니다. 예를 들어, Service 객체, DAO 객체, Command 객체 등이 Servlet Container에 담길 수 있습니다. 이러한 객체들은 FrontController에서 요청을 처리할 때 필요한 작업을 수행하기 위해 사용됩니다.

하지만 이 경우, 각 객체들의 생명 주기와 관련된 문제가 발생할 수 있습니다. 객체들이 일정 시간 이상 Servlet Container에 유지되어 있으면 메모리 누수 문제가 발생하게 됩니다. 따라서 객체들의 생명 주기 관리를 위해서는 DI(Dependency Injection) 패턴을 이용하여 필요한 객체를 동적으로 생성하고 소멸시키는 방법을 사용할 수 있습니다.

이와 관련된 자세한 내용은 Spring Framework와 같은 프레임워크에서 제공하는 DI 컨테이너를 참고하시면 도움이 될 것 같습니다.

좋은 결과가 있길 바랍니다. 감사합니다.

newh08님의 프로필 이미지
newh08

작성한 질문수

질문하기