인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

wlsl3472님의 프로필 이미지
wlsl3472

작성한 질문수

스프링 핵심 원리 - 기본편

스코프와 Provider

myLoggerProvider.getObject() 메서드시 동시성관련 질문있습니다.

해결된 질문

작성

·

247

0


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

[질문 내용]

클라이언트1,2,3,4,5이 동시에요청했을때

myLoggerProvider.getObject()실행해서 my Logger 객체를 받아올때 (컨트롤러or서비스)

request요청이 여러개니까 myLogger객체는 이때 여러개인데...

똑같은 객체가 계속 반환되는걸 보장해주는 이유가 있나요?

 

 

@PostConstruct
public void init(){
     uuid = UUID.randomUUID().toString();
    System.out.println("[" + uuid + "]" + "request scope bean create: "+this);
}

거의 동시에 요청이왔다고 가정했을때

init해서 각 request스코프객체에 UUID각각설정후

getObject()를 각자 두번씩해서 myLogger를 얻게되는데

이때 myLogger타입 객체는 여러개가있을수있고

이걸 init했을때-처음getObject()-두번쨰getObject-close

이런순서로 진행될때

처음 init할떄랑 close할때는 객체주소가 같은건 당연하지만

그사이에 getObject()했을때 객체가 바뀔우려가 있는건 아닌지 생각이듭니다

 

 @RequestMapping("log-demo")
 @ResponseBody
public String logDemo(HttpServletRequest request) throws InterruptedException {


    MyLogger myLogger = myLoggerObjectProvider.getObject(); <================여기


    String requestURL = request.getRequestURL().toString();
    myLogger.setRequestURL(requestURL);

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






public class LogDemoService {

    private final ObjectProvider<MyLogger> myLoggerObjectProvider;

    public void logic(String id) {
        MyLogger myLogger = myLoggerObjectProvider.getObject();<==========여기
        myLogger.log("service id = "+ id);
    }

답변 3

0

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

감사합니다! 이해가잘됐어요

0

안녕하세요. wlsl3472님, 공식 서포터즈 David입니다.

요청 스코프 빈의 경우 빈이 생성된 후 요청 객체 내에 저장됩니다.

따라서, 동일 요청이라면 이미 생성되어 저장된 객체를 조회하여 반환하기 때문에 동일한 객체가 반환됨이 보장됩니다.

감사합니다.

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

MyloggerObjectProvider는 싱글톤이고 getObject해서 Mylogger조회해서 가져올때 대상은 여러개가되는데...

이때 어떻게 조회를해서 분별하냐는 질문이였습니다.

init할때 식별자를 부여한다던가...?

MyLogger가 생성되면, 싱글톤 컨테이너가 아닌 요청 객체 내에 보관됩니다.

한 요청에는 하나의 MyLogger만 존재하게 됩니다.

따라서, 해당 요청 내에서는 동일한 MyLogger 객체 반환을 보장합니다.

0

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

혹시

AnnotationConfigServletWebServerApplicationContext로 동작하니까

Httprequest헤더의 정보롤 읽어서

같은 bean을 계속 반환할수 있도록 한다는 건가요?

 

6분에 멈춰놓고 고민했는데

7분부터 간단한 설명이나오네요

그렇다면 HttpRequest에서 어떤정보를 읽어서 구분을 하는걸까요?

어플리케이션계층에서 식별할만한 특별한게 있는지 잘모르겠네요

wlsl3472님의 프로필 이미지
wlsl3472

작성한 질문수

질문하기