Sun Java System Message Queue 3.7 UR1 기술 개요

JMS/J2EE 프로그래밍: Message-Driven Bean

2 장, 클라이언트 프로그래밍 모델에서 소개한 일반적인 JMS 클라이언트 프로그래밍 모델 외에도 J2EE 플랫폼 응용 프로그램 컨텍스트에서 사용하는, 보다 특수화된 JMS 버전이 있습니다. 이 특수화된 클라이언트를 Message-Driven Bean이라고 부르며, EJB(Enterprise JavaBeans) 구성 요소 중 하나로서EJB 2.0 이상 사양(http://java.sun.com/products/ejb/docs.html)에 설명되어 있습니다.

Message-Driven Bean은 비동기식 메시징을 제공합니다. 다른 EJB 구성 요소(Session Bean과 Entity Bean)는 표준 EJB 인터페이스를 통한 동기식 호출만 가능합니다. 그러나 엔터프라이즈 응용 프로그램에서는 서버측 구성 요소가 서버 자원을 독점하는 일 없이 통신할 수 있도록 비동기식 메시징이 필요할 때가 많습니다. 서버측 구성 요소가 응용 프로그램 이벤트에 응답해야 하는 응용 프로그램에서는 메시지 제작자와 밀접하게 연결되지 않으면서 메시지를 수신하고 소비할 수 있는 EJB 구성 요소가 필요합니다. 또한 엔터프라이즈 응용 프로그램에서 이러한 기능은 로드 증가에 따라 확장되어야 합니다.

MDB(Message-Driven Bean)는 특수한 EJB 컨테이너가 지원하는 EJB 구성 요소이며, 해당 컨테이너는 지원하는 구성 요소에 대해 분산 서비스를 제공합니다.

그림 5–1 MDB와의 메시지

J2EE 환경에서 JMS 메시지 제작자가 메시지를 소비할 MDB 인스턴스에게 메시지를 보내는 다이어그램