목록BE (354)
오봉이와 함께하는 개발 블로그
스코프와 Provider 간단하게 ObjectProvider를 사용해서 해결하자 ObjectProvider @Controller @RequiredArgsConstructor public class LogDemoController { private final LogDemoService logDemoService; private final ObjectProvider myLoggerProvider; @RequestMapping("log-demo") @ResponseBody public String logDemo(HttpServletRequest request) { String requestURL = request.getRequestURL().toString(); MyLogger myLogger = myLogg..
웹 스코프 웹 스코프는 웹 환경에서만 동작한다. 웹 스코프는 프로토타입과 다르게 스프링이 해당 스코프의 종료시점까지 관리하기 때문에 종료 메소드가 호출된다. 웹 스코프의 종류 request HTTP 요청 하나가 들어오고 나갈 때 까지 유지되는 스코프 각각 HTTP 요청마다 별도의 빈 인스턴스가 생성되고 관리된다. session HTTP Session과 동일한 생명주기를 가진다. application 서블릿 컨텍스트(ServletContext)와 동일한 생명주기를 가진다. websocket 웹 소켓과 동일한 생명주기를 가진다. request 스코프 예제 만들기 우선 웹 스코프를 위해 웹 환경을 추가하자. // build.gradle에 추가 implementation 'org.springframewo..
프로토타입 스코프 - 싱글톤 빈과 함께 사용시 Provider로 문제 해결 싱글톤 빈과 프로토타입을 같이 사용할 때 어떻게 하면 항상 새로운 프로토타입 빈을 생성할 수 있을까? static class ClientBean { @Autowired private ApplicationContext ac; public int logic() { PrototypeBean prototypeBean = ac.getBean(PrototypeBean.class); prototypeBean.addCount(); int count = prototypeBean.getCount(); return count; } } ac.getBean()을 통해 항상 새로운 프로토타입 빈이 생성되는 것을 확인할 수 있다. 의존관계를 외부에서 주입(..
프로토타입 스코프 - 싱글톤 빈과 함께 사용시 문제점 프로토타입 스코프의 빈을 요청하면 항상 새로운 객체 인스턴스를 생성해서 반환한다. 하지만, 싱글톤 빈과 함께 사용할 때는 의도한대로 동작하지 않기 때문에 주의해야 한다. 프로토타입 빈 직접 요청 클라이언트A는 스프링 컨테이너에 프로토타입 빈을 요청 스프링 컨테이너는 프로토타입 빈을 새로 생성해서 반환(x01). 해당 빈의 count 필드 값은 0이다. 클라이언트는 조회한 빈에 addCount()를 호출해서 count 필드를 +1 한다. 결과적으로 프로토타입 빈(x01)의 count는 1이 된다. 클라이언트B는 스프링 컨테이너에 프로토타입 빈을 요청 스프링 컨테이너는 프로토타입 빈을 새로 생성해서 반환(x02). 해당 빈의 count 필드 값은 0이다...
빈 스코프란? 스프링 빈이 스프링 컨테이너의 시작과 함께 생성되어 스프링 컨테이너가 종료될 때 까지 유지된다 알고 있었다. 하지만 이것은 스프링 빈이 기본적으로 싱글톤 스코프로 생성되기 때문이다. 스코프는 번역 그대로 빈이 존재할 수 있는 범위를 뜻한다. 스프링이 지원하는 스코프 싱글톤 스코프 기본 스코프 스프링 컨테이너의 시작과 종료까지 유지되는 가장 넓은 범위의 스코프 프로토타입 스프링 컨테이너는 프로토타입 빈의 생성과 의존관계 주입, 초기화 메소드까지만 관여하고 클라이언트에게 반환해 더는 관리하지 않는 매우 짧은 범위의 스코프 웹 관련 스코프 request : 웹 요청이 들어오고 나갈때 까지 유지 request로 들어와서 response로 나갈때 까지 유지 session : 웹 세션이 생성되고 종료..