[jboss-user] [Management, JMX/JBoss] - [subscription-list: null] message in logs, cannot create a n

weinstock.gabriel do-not-reply at jboss.com
Mon Jun 4 16:16:42 EDT 2007


Hi,
  I'm trying to create an XMBean that listens for notifications from a Timer XMBean. It should simply log the notification and handback when it receives one. However, I never see the logging statement indicating my MBean has started up (or shut down for that matter), and when I look at the logs, I see these entries around my code:


  | 2007-06-04 15:11:23,960 DEBUG [org.jboss.system.ServiceCreator] About to create xmbean object: domain.com:service=OmsService with code: com.domain.oms.xmbeans.impl.OmsService with descriptor: META-INF/oms-xmbean.xml
  | 2007-06-04 15:11:23,991 DEBUG [org.jboss.system.ServiceCreator] Created bean: domain.com:service=OmsService
  | 2007-06-04 15:11:23,991 DEBUG [org.jboss.system.ServiceConfigurator] SubscriptionList set to [subscription-list: null] in domain.com:service=OmsService
  | 

I'm putting all of my class files, the jboss-service.xml, and the oms-xmbean.xml file in a .sar file (oms.sar) and deploying to a JBoss 4.2.0 GA server. Here are the two source code files:

OmsService.java:


  | package com.domain.oms.xmbeans.impl;
  | 
  | import org.jboss.system.ListenerServiceMBeanSupport;
  | import org.jboss.logging.Logger;
  | 
  | import javax.management.Notification;
  | 
  | import com.domain.oms.xmbeans.OmsServiceMBean;
  | 
  | public class OmsService extends ListenerServiceMBeanSupport implements OmsServiceMBean {
  | 	private static final Logger LOG = Logger.getLogger(OmsService.class.getName());
  | 	
  | 	public OmsService() {
  | 		super();
  | 	}
  | 	/*
  | 	public String getName() {
  | 		return "OmsService";
  | 	}
  | 	*/
  | 	public void startService() throws Exception {
  | 		LOG.info("oms service starting up");
  | 		super.subscribe(true);
  | 	}
  | 	
  | 	public void stopService() throws Exception {
  | 		LOG.info("stopping oms service");
  | 		super.unsubscribe();
  | 	}
  | 	
  | 	public void handleNotification2(Notification notification, Object handback) {
  | 		LOG.info("got " + notification + ", " + handback);
  | 	}
  | }
  | 

OmsServiceMBean.java:


  | package com.domain.oms.xmbeans;
  | 
  | import org.jboss.system.ListenerServiceMBean;
  | 
  | public interface OmsServiceMBean extends ListenerServiceMBean {
  | }
  | 

And the .xml files:

jboss-service.xml:


  | <?xml version="1.0" encoding="UTF-8"?>
  | <!DOCTYPE server PUBLIC "-//JBoss//DTD MBean Service 4.2//EN" "http://www.jboss.org/j2ee/dtd/jboss-service_4_2.dtd">
  | <server>
  | 	<mbean code="com.domain.oms.xmbeans.impl.OmsService" name="domain.com:service=OmsService" xmbean-dd="META-INF/oms-xmbean.xml">
  | 		<attribute name="SubscriptionList">
  | 			<subscription-list>
  | 				<mbean name="jboss.monitor:name=Heartbeat,type=Timer">
  |  					<notification type="jboss.monitor.heartbeat"/>
  | 				</mbean>
  | 			</subscription-list>
  | 		</attribute>
  | 	</mbean>
  | </server>
  | 

oms-xmbean.xml:


  | <?xml version="1.0" encoding="UTF-8"?>
  | <!DOCTYPE mbean PUBLIC "-//JBoss//DTD JBOSS XMBEAN 1.2//EN" "http://www.jboss.org/j2ee/dtd/jboss_xmbean_1_2.dtd">
  | <mbean>
  |     <description>oms service</description>
  |     <class>com.domain.oms.xmbeans.impl.OmsService</class>
  |     <constructor>
  |         <description>the default constructor</description>
  |         <name>OmsService</name>
  |     </constructor>
  |     <attribute access="write-only" setMethod="setSubscriptionList">
  |     	<name>SubscriptionList</name>
  | 		<type>org.w3c.dom.Element</type>
  |     </attribute>
  | 	<operation>
  | 		<name>startService</name>
  | 		<return-type>void</return-type>
  | 	</operation>
  | 	<operation>
  | 		<name>stopService</name>
  | 		<return-type>void</return-type>
  | 	</operation>
  | 	<operation>
  | 		<name>handleNotification2</name>
  | 		<parameter>
  | 			<name>notification</name>
  | 			<type>javax.management.Notification</type>
  | 		</parameter>
  | 		<parameter>
  | 			<name>handback</name>
  | 			<type>java.lang.Object</type>
  | 		</parameter>
  | 		<return-type>void</return-type>
  | 	</operation>
  | </mbean>
  | 

Can someone tell me what I'm doing wrong? I've been debugging this for the last 4 days and getting nowhere. I can't determine why the subscription-list element is coming back null, or why the service start method is never invoked.

By the way, I did enable the Timer (heartbeat) service in jboss-monitoring.xml.

Any help would be SO greatly appreciated,
Thanks,
Gabe

View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4051095#4051095

Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4051095



More information about the jboss-user mailing list