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

서정원님의 프로필 이미지
서정원

작성한 질문수

스프링 핵심 원리 - 기본편

스코프와 Provider

myLoggerProvider.getObject질문

작성

·

498

0

LogDemoController에서

@RequestMapping("log-demo")
@ResponseBody
public String logDemo(HttpServletRequest request){
    MyLogger myLogger = myLoggerProvider.getObject();
    String requestURL = request.getRequestURL().toString();
    myLogger.setRequestURL(requestURL);

    myLogger.log("controller test");
    logDemoService.logic("testId");
    return "OK";
}

myLoggerProvider.getObject를 했을 때 myLogger를 반환하는것은 이해했습니다. 그러나 logDemoService.logic("testId")를 실행하면

@Service
@RequiredArgsConstructor
public class LogDemoService {

    private final ObjectProvider<MyLogger> myLoggerProvider;
    public void logic(String id) {
        MyLogger myLogger = myLoggerProvider.getObject();
        myLogger.log("service id=" +id);
    }
}

이 코드가 실행될텐데 logic(String id)로만 되어있지 HttpServletRequest와 관련된 코드가 없는데 어떻게 logic(String id)메서드 안에서 myLoggerProvider.getObject()를 했을 때 같은 myLogger가 가져와지는지 궁금합니다. 혹시 HttpServletRequest가 return"OK";를 해서 끝날때까지 쭉 들고가는 느낌? 이라고 해야할까요? 그런식으로 해서 스프링이 알아서 logic()메서드 안에서도 알 수 있어서 같은 myLogger를 반환하는것인지 궁금합니다.

답변 3

0

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

안녕하세요. 서정원님

어떤 점이 궁금한지 이해가 되는데요.

이 부분을 제대로 이해하려면 쓰레드 로컬이라는 개념을 알아야 합니다.

쓰레드 로컬은 스프링 핵심원리 고급편에서 자세히 설명드립니다 🙂

감사합니다.

0

서정원님의 프로필 이미지
서정원
질문자

LogDemoService에서 ObjectProvider.getObject()를 호출할 때 어떻게 같은HTTP 요청 내에서 실행되는걸 아는지 궁금합니다!

0

안녕하세요, 인프런 AI 인턴입니다. 서정원 님의 질문은 스프링의 request 스코프 빈이 다른 컴포넌트(여기서는 컨트롤러와 서비스)에 주입될 때, 어떻게 하나의 HTTP 요청에 대해 동일한 빈 인스턴스를 반환하는지에 대한 것인 것 같습니다.

해당 질문은 request 스코프의 빈이 어떻게 동작하는지에 대한 이해를 바탕으로 합니다. request 스코프는 각각의 HTTP 요청을 기반으로 빈을 생성하고 관리합니다. 즉, 하나의 HTTP 요청이 들어오면 관련된 빈은 그 요청이 종료될 때까지 존재하게 되며, 요청 내에서는 모두 같은 인스턴스를 반환합니다.

LogDemoService 에서 ObjectProvider를 쓰는 이유 질문에서, 강의의 지식공유자께서는 request 스코프와 프록시 관련하여 궁금증을 해소해드리려고 답변을 해주셨습니다. 요청이 오기 전에는 실제 myLogger 빈이 존재하지 않기 때문에 생성자 주입을 사용할 수 없고, ObjectProvider.getObject() 메서드를 통해서 요청 시점에 빈을 요청하게 됩니다. 이것은 서로 다른 컴포넌트에서 동일한 HTTP 요청에 대해서 같은 myLogger 인스턴스를 사용할 수 있도록 해줍니다.

따라서 LogDemoControllerLogDemoService에서 ObjectProvider.getObject()를 호출할 때, 같은 HTTP 요청 내에서 실행된다면 동일한 빈 인스턴스를 반환받게 됩니다. HTTP 요청이 종료될 때까지 myLogger는 고유하며, 같은 요청 내에서는 어느 곳에서 가져오든 동일한 인스턴스를 참조하게 됩니다.

HttpServletRequest 객체는 스프링 MVC에서 자동으로 관리되기 때문에 개발자가 직접 관리할 필요는 없지만, request 스코프 빈을 사용하는 곳에서는 해당 요청과 연결된 동일한 myLogger 인스턴스에 접근할 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

서정원님의 프로필 이미지
서정원
질문자

LogDemoService에서 ObjectProvider.getObject()를 호출할 때 어떻게 같은HTTP 요청 내에서 실행되는걸 아는지 궁금합니다!

서정원님의 프로필 이미지
서정원

작성한 질문수

질문하기