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 •
?

  1. 리눅스(Linux) 디렉토리 구조

    Date2016.10.20 ByJAESOO Views602
    Read More
  2. ssh서버가 비밀번호를 거부했습니다. 다시 시도하십시오.

    Date2016.08.26 ByJAESOO Views709
    Read More
  3. [리눅스] IP 설정 변경 하기

    Date2016.08.26 ByJAESOO Views717
    Read More
  4. 리눅스 설치후 초기설정해야 할 것들 [2]

    Date2016.07.13 ByJAESOO Views675
    Read More
  5. 리눅스 설치후 초기설정해야 할 것들 [1]

    Date2016.07.13 ByJAESOO Views702
    Read More
  6. 쉘 프로그래밍을 이용한 시스템 관리 기법

    Date2016.05.12 ByJAESOO Views540
    Read More
  7. AIX 자주 쓰이는 관리 명령 모음

    Date2016.05.12 ByJAESOO Views554
    Read More
  8. AIX 시스템상의 core, SMT(Simultaneous Multi Threading) 수 확인하기

    Date2016.05.12 ByJAESOO Views604
    Read More
  9. 리눅스 호스트명 변경

    Date2016.05.11 ByJAESOO Views439
    Read More
  10. AIX 서버 기초

    Date2016.05.11 ByJAESOO Views560
    Read More
  11. AIX Admin Study 교육 자료

    Date2016.05.11 ByJAESOO Views547
    Read More
  12. 성능 엔지니어링 대한 접근 방법 (Performance tuning)

    Date2016.05.05 ByJAESOO Views489
    Read More
  13. [AIX] 파일시스템 관리 (du, df)

    Date2016.05.04 ByJAESOO Views552
    Read More
  14. IBM AIX Admin (사용자 DISK 관리)

    Date2016.05.04 ByJAESOO Views504
    Read More
  15. [UNIX] 유닉스 기본명령어

    Date2016.05.04 ByJAESOO Views455
    Read More
  16. [AIX] 파일시스템 용량 늘리기

    Date2016.05.04 ByJAESOO Views558
    Read More
  17. 유닉스 상에서 ls 출력물을 MB 단위로 출력해주는 옵션

    Date2016.05.04 ByJAESOO Views446
    Read More
  18. ls 명령시 날짜 전체가 보이도록 하기

    Date2016.05.02 ByJAESOO Views438
    Read More
  19. 리눅스 logrotate 에서 로그파일 강제로 rotate 시키기

    Date2016.03.31 ByJAESOO Views663
    Read More
  20. 리눅스 시간 맞추기 : Time Server와 Sync (rdate, date)

    Date2016.03.19 ByJAESOO Views733
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

PageViews   Today : 7976 Yesterday : 5037 Total : 21964028  /  Counter Status   Today : 7694 Yesterday : 4602 Total : 1190417

Edited by JAESOO

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


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

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

설치 취소