RadarURL
Skip to content
조회 수 597 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

struts2 를 이용해 Controller 를 구성할때는 해당 Controller가 prototype 으로 생성되 각 쓰레드별로 Heap 메모리에 객체를 동적으로 생성하고 사용하는 것으로 알고 있습니다.

이로 인해 요청이 올때마다 메모리에 대한 부담이 클것이라고 생각했는데, spring MVC 테스트 도중 spring의 Controller는 singleton으로 생성되는 것을 알게 되었는데, 그렇다면 Contoller를 구성하는데 이 두가지 방식에 차이가 있지 않을까 라는 궁금증이 생겼습니다.

여지껏 알고있던 Contoller 라는 녀석은 요청시마다 쓰레드별로 heap메모리에 객체를 생성해, 쓰레드 Safe한 상태라고 생각했는데 Spring MVC에서의 contoller는 singleton이라니.. 그렇다면 하나의 객체로 여러 쓰레드에게 제공되기 때문에 쓰레드 Safe 하지 않지 않을까 라는 궁금증이 들기 시작했습니다. Safe 하지 않다면, 객체 내의 상태관리를 어떻게 할것인가..

이에 대해 알아보니

  • Spring 에서 지원하는 singleton 인스턴스는 Non EJB 아키텍쳐에서 많이 사용한 singleton 디자인 패턴을 이용하여 구현하는 것이 아니라 어플리케이션 저장소(Registry)를 이용하여 구현하는 방식을 이용하고 있다고 합니다.


  • Spring에서 Registry 역할을 하는 클래스는 ApplicationContext 이고, singleton 인스턴스로 관리되는 모든 POJO빈은 ApplicationContext내에 있는 HashMap에 Key & Value 로 저장해두기때문에 bean에 접근하고자 할때 HashMap에서 bean 인스턴스를 얻게 되기때문에, singleton 디자인 패턴을 이용할 경우 발생되는 문제점을 해결하는 것이 가능하다 라고 하네요


* singleton 디자인 패턴의 문제점에 대한 자세한 내용은
http://wiki.javajigi.net/pages/viewpage.action?pageId=527&decorator=printable에 잘 정리되 있습니다.

추가적으로 다음과 같은 경우 singleton 인스턴스로 관리 가능하다고 합니다.

- 생성되는 인스턴스 내에 공유되는 상태가 없는 경우
- 생성되는 인스턴스 내에 read-only 상태만 있는 경우
- 생성되는 인스턴스 내에 공유되는 상태가 있더라도 상태를 변경할 때 동기화를 보장 할 수 있는 경우

출처 : http://stunstun.tistory.com/30

TAG •
?

List of Articles
번호 제목 글쓴이 날짜 조회 수
162 페도라12 yum(rpm)으로 APM 설치 (수호신패치 포함) JaeSoo 2011.06.08 12310
161 특별한 퍼미션 setuid setgid sticky bit JAESOO 2015.05.27 554
160 톰캣(Tomcat) 실시간 로그보기 JAESOO 2015.04.13 1069
159 좀비 프로세스 찾기, 죽이기 JAESOO 2015.05.27 898
158 유닉스 상에서 ls 출력물을 MB 단위로 출력해주는 옵션 JAESOO 2016.05.04 446
157 웹서버 CentOS 6.5 MRTG 설치 JAESOO 2014.12.26 1006
156 올바른 자바 프레임워크 선택하기 JAESOO 2014.05.09 1044
155 안전한 CentOS를 위한 방화벽, 보안 설정 JAESOO 2014.05.26 2093
154 아파치서버 동시접속자수에 따른 메모리 산정 (대략) JAESOO 2015.01.13 1613
153 시스템 관리자가 알아야 할 리눅스 모니터링 툴 20선 (20 Linux System Monitoring Tools Every SysAdmin Should Know) JAESOO 2014.05.29 2301
152 스프링 프레임워크(Spring Framework) 버전(version) 확인하기 JAESOO 2014.05.09 1368
151 스트러츠와 스프링의 비교 JAESOO 2014.05.09 1414
150 쉘 프로그래밍을 이용한 시스템 관리 기법 JAESOO 2016.05.12 540
149 성능 엔지니어링 대한 접근 방법 (Performance tuning) JAESOO 2016.05.05 489
148 리눅스에서 일반 계정으로 httpd 80포트 실행하기 JAESOO 2014.05.26 1106
147 리눅스에서 MYSQL 데이터 디렉토리 변경 JAESOO 2014.06.04 2015
146 리눅스에서 i386,i586,i686, x86의 차이점 JAESOO 2014.05.30 2176
145 리눅스로 MRTG 트래픽분석서버 구축 JAESOO 2014.12.26 730
144 리눅스(Linux)에서 하위 디렉토리까지 파일 찾기, 찾아서 지우기 JAESOO 2015.02.24 1232
143 리눅스(Linux) 디렉토리 구조 JAESOO 2016.10.20 602
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

PageViews   Today : 8083 Yesterday : 5037 Total : 21964135  /  Counter Status   Today : 7800 Yesterday : 4602 Total : 1190523

Edited by JAESOO

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소