Java 2 Platform, Enterprise Edition(J2EE 플랫폼)은 다중 계층 및 서버의 시스템 기능에 의존하는 클라이언트 엔터프라이즈 응용 프로그램을 호스트하는 표준 서버 플랫폼의 사양입니다. J2EE 플랫폼의 요구 사항 중 하나는 분산 구성 요소가 안정적인 비동기식 메시징을 통해 상호 작용할 수 있어야 한다는 것입니다. 이러한 상호 작용은 JMS 공급자를 사용하면 가능합니다. 실제로 Message Queue는 J2EE 플랫폼의 참조 JMS 구현입니다.
이 장에서는 J2EE 플랫폼 환경에서 JMS 지원을 구현한 결과를 살펴봅니다. 이 장은 다음 내용으로 구성되어 있습니다.
Message Queue를 J2EE 호환 응용 프로그램 서버를 위한 JMS 공급자로 사용하는 것에 대한 자세한 내용은 Sun Java System Message Queue 3.7 UR1 관리 설명서의 17 장, JMS Resource Adapter Property Reference를 참조하십시오.
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 구성 요소이며, 해당 컨테이너는 지원하는 구성 요소에 대해 분산 서비스를 제공합니다.
JMS MDB(message driven bean)는 JMS MessageListener 인터페이스를 구현하는 EJB입니다. onMessage 메소드(MDB 개발자가 작성)는 MDB 컨테이너가 메시지를 수신할 때 호출됩니다. onMessage() 메소드는 표준 MessageListener 객체의 onMessage() 메소드처럼 이 메시지를 소비합니다. MDB에서는 다른 EJB 구성 요소에서처럼 메소드를 원격 호출하지 않습니다. 따라서 그와 연관된 홈 또는 원격 인터페이스가 없습니다. MDB는 단일 대상에서 온 메시지를 소비할 수 있습니다. 그림 5–1에서 확인할 수 있듯이 독립형 JMS 응용 프로그램, JMS 구성 요소, EJB 구성 요소 또는 웹 구성 요소에서 메시지를 생성할 수 있습니다.
특수한 EJB 컨테이너가 MDB를 지원합니다. MDB의 인스턴스를 만들고 이 인스턴스가 비동기식으로 메시지를 소비하도록 설정합니다. 이 컨테이너는 메시지 서비스와 연결을 설정하고(인증 포함), 지정된 대상과 연관된 세션 풀을 생성하며 풀링된 세션 간의 메시지 배포를 관리합니다. 이 컨테이너는 MDB 인스턴스의 라이프사이클을 제어하므로 MDB 인스턴스 풀에서 받는 메시지 로드를 수용할 수 있도록 관리합니다.
MDB와 관련된 배포 설명자는 컨테이너가 메시지 소비 설정 시 사용하는 연결 팩토리 및 대상 속성을 지정합니다. 이 배포 설명자는 배포 도구에서 컨테이너 구성 시 필요로 하는 다른 정보를 포함할 수도 있습니다. 이 컨테이너 각각은 단일 MDB 인스턴스를 지원합니다.
J2EE 아키텍처에서 EJB 컨테이너는 J2EE Application Server가 호스팅합니다. Application Server는 트랜잭션 관리자, 지속성 관리자, 이름 서비스 그리고 메시징과 MDB의 경우 JMS 공급자 등 다양한 컨테이너에서 필요로 하는 자원을 제공합니다.
Sun Java System Application Server의 경우 JMS 메시징 자원은 Sun Java System Message Queue에서 제공합니다.
Sun Java System Application Server 7.0의 경우 Message Queue 메시징 시스템이 Application Server에 원시 JMS 공급자로 통합되어 있습니다.
Sun J2EE 1.4 Application Server의 경우 Message Queue가 Application Server에 내장된 JMS 자원 어댑터로 플러그인되어 있습니다.
Application Server의 향후 릴리스에서는 Message Queue가 표준 자원 어댑터 배포 및 구성 방법을 사용하는 Application Server에 플러그인됩니다.
J2EE 아키텍처에 대한 자세한 내용은 J2EE 플랫폼 사양(http://java.sun.com/j2ee/download.html#platformspec)을 참조하십시오.
자원 어댑터는 J2EE 1.4를 준수하는 Application Server에 추가 기능을 플러그인하는 표준화된 방법입니다. J2EE Connector Architecture(J2EECA) 1.5 사양에 의해 정의되는 이 표준에 따라 Application Server가 표준 방식으로 외부 시스템과 상호 작용할 수 있습니다. 외부 시스템은 EIS(Enterprise Information System)를 비롯하여 JMS 공급자와 같은 메시징 시스템을 포함할 수 있습니다. Message Queue에는 Application Server가 Message Queue를 JMS 공급자로 사용할 수 있도록 JMS 자원 어댑터가 포함되어 있습니다.
JMS 자원 어댑터를 Application Server에 플러그인하면 Application Server에서 배포되어 실행 중인 J2EE 구성 요소가 JMS 메시지를 교환할 수 있습니다. 이러한 구성 요소에 필요한 JMS 연결 팩토리 및 대상 관리 객체는 J2EE Application Server 관리 도구를 사용하여 만들고 구성할 수 있습니다.
그러나 브로커 관리 및 물리적 대상 관리와 같은 다른 관리 작업은 J2EECA 사양에 포함되어 있지 않으므로 공급자 고유의 도구를 통해서만 수행할 수 있습니다.
Message Queue 자원 어댑터는 Sun J2EE 1.4 Application Server에 통합되어 있습니다. 그러나 다른 J2EE 1.4 Application Server에서는 아직 인증되지 않았습니다.
Message Queue 자원 어댑터는 운영 체제에 종속된 디렉토리에 있는 단일 파일(imqjmsra.rar)입니다(Sun Java System Message Queue 3.7 UR1 관리 설명서의 17 장, JMS Resource Adapter Property Reference). imqjmsra.rar 파일은 자원 어댑터 배포 설명자(ra.xml)를 비롯하여 어댑터를 사용하기 위해 Application Server에서 필요한 JAR 파일도 포함합니다.
모든 J2EE -1.4 호환 Application Server에서 해당 Application Server와 함께 제공되는 자원 어댑터 배포 및 구성 지침에 따라 Message Queue 자원 어댑터를 사용할 수 있습니다. 상용 J2EE 1.4 Application Server가 출시되고 Message Queue 자원 어댑터가 이러한 Application Server에서 인증되면 Message Queue 문서에서 관련 배포 및 구성 절차에 대한 구체적인 정보를 제공할 것입니다.