21.4. 런타임 제어
21.4.1. 개요
런타임 시 WS-RM을 제어하기 위해 클라이언트 코드에서 여러 메시지 컨텍스트 속성 값을 설정할 수 있으며, org.apache.cxf.ws.rm.RMManager
클래스에 공용 상수로 정의된 키 값을 사용할 수 있습니다.
21.4.2. 런타임 제어 옵션
다음 표에는 org.apache.cxf.ws.rm.RMManager
클래스에서 정의된 키가 나열되어 있습니다.
키 | 설명 |
---|---|
|
string WS-RM 버전 네임스페이스( |
|
문자열 WS-Addressing 버전 네임스페이스( |
|
WS-RM 코드에서 마지막 메시지가 전송되고 있음을 나타내기 위해 |
| 비활성 기간(밀리초)입니다. |
| 긴 기본 재전송 간격(밀리초)입니다. |
| 부울 지수 백오프 플래그입니다. |
| 장기 승인 간격(밀리초)입니다. |
21.4.3. JMX를 통한 WS-RM 제어
Apache CXF의 JMX 관리 기능을 사용하여 WS-RM의 여러 측면을 모니터링하고 제어할 수도 있습니다. JMX 작업의 전체 목록은 org.apache.cxf.ws.ManagedRMManager 및
에 의해 정의되지만 이러한 작업에는 현재 RM 상태를 개별 메시지 수준으로 보는 작업이 포함됩니다. JXM을 사용하여 WS-RM 시퀀스를 종료하거나 종료하고 이전에 전송된 메시지가 원격 RM 끝점에 의해 승인될 때 알림을 받을 수도 있습니다.
org.
apache.cxf.ws.rm.ManagedRMEndpoint
21.4.4. JMX 제어의 예
예를 들어 클라이언트 구성에 JMX 서버가 활성화된 경우 다음 코드를 사용하여 수신된 마지막 승인 번호를 추적할 수 있습니다.
// Java private static class AcknowledgementListener implements NotificationListener { private volatile long lastAcknowledgement; @Override public void handleNotification(Notification notification, Object handback) { if (notification instanceof AcknowledgementNotification) { AcknowledgementNotification ack = (AcknowledgementNotification)notification; lastAcknowledgement = ack.getMessageNumber(); } } // initialize client ... // attach to JMX bean for notifications // NOTE: you must have sent at least one message to initialize RM before executing this code Endpoint ep = ClientProxy.getClient(client).getEndpoint(); InstrumentationManager im = bus.getExtension(InstrumentationManager.class); MBeanServer mbs = im.getMBeanServer(); RMManager clientManager = bus.getExtension(RMManager.class); ObjectName name = RMUtils.getManagedObjectName(clientManager, ep); System.out.println("Looking for endpoint name " + name); AcknowledgementListener listener = new AcknowledgementListener(); mbs.addNotificationListener(name, listener, null, null); // send messages using RM with acknowledgement status reported to listener ...