RadarURL

응용 프로그래밍
2014.05.09 18:12

Struts와 Spring의 Controller 의 차이는?

조회 수 1259 추천 수 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
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 927892
1746 응용 프로그래밍 Spring MVC 에서 ContentNegotiatingViewResolver를 이용한 단일 RequestMapping 으로 Muilti-View 처리하기 file JaeSoo 2014.05.09 1687
» 응용 프로그래밍 Struts와 Spring의 Controller 의 차이는? JaeSoo 2014.05.09 1259
1744 응용 프로그래밍 Spring MVC file JaeSoo 2014.05.09 1591
1743 응용 프로그래밍 올바른 자바 프레임워크 선택하기 JaeSoo 2014.05.09 1400
1742 응용 프로그래밍 스프링 프레임워크(Spring Framework) 버전(version) 확인하기 JaeSoo 2014.05.09 2134
1741 응용 프로그래밍 스트러츠와 스프링의 비교 JaeSoo 2014.05.09 1148
1740 웹서버,WAS Apache Struts 버전 확인 방법 JaeSoo 2014.05.09 1998
1739 윈도우즈 Chkdsk.exe에서 사용할 수 있는 새로운 /C 및 /I 스위치에 대한 설명 JaeSoo 2014.05.08 1531
1738 웹 프로그래밍 PHP MySQL 명령어 실행 함수 mysql_query JaeSoo 2014.04.29 1669
1737 데이터베이스 mariadb 원격 접속 허용 JaeSoo 2014.04.29 1477
1736 유닉스/리눅스 vsftp root로 접속하기 JaeSoo 2014.04.29 1491
1735 유닉스/리눅스 touch (파일의 날짜시간정보를 변경) JaeSoo 2014.04.29 1445
1734 데이터베이스 오라클 업데이트, 딜리트 쿼리 (oracle update, delete query) JaeSoo 2014.04.19 2031
1733 웹 프로그래밍 제로보드 XE에서 무분별한 스팸글 등록으로부터 임시 해결 팁 JaeSoo 2014.04.19 2088
1732 업무 회사 조직 영문표기(Organizational Chart) JaeSoo 2014.04.16 1694
1731 업무 입찰기초 공부하기 (입찰 안내서) - 입찰준비 과정, 참가등록 방법, 공동도급 관련 내용 등 file JaeSoo 2014.04.14 1748
1730 윈도우즈 Windows 7에서 자동 로그인 설정하기 file JaeSoo 2014.04.12 1686
1729 웹 프로그래밍 자주 발생하는 소켓 에러(Socket Error) JaeSoo 2014.04.11 3903
1728 웹서버,WAS robots.txt를 현명하게 사용하는 방법 JaeSoo 2014.04.11 1481
1727 웹서버,WAS robots.txt 파일(로봇배제 표준) JaeSoo 2014.04.11 1378
Board Pagination Prev 1 ... 32 33 34 35 36 37 38 39 40 41 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너