我根据另一个问题的建议做了一些更改,将我的课变为@Singleton
而不是@Stateless
,但是我不再在@MessageDriven
Bean中接收消息了之前。建议?请注意,该主题已在jbossmq-destinations-service.xml
@javax.ejb.Singleton(mappedName="MySingletonClass")
public class MySingletonClass implements SomeInterface
{
private Timer timer = null;
@javax.annotation.Resource
TimerService timerService;
/**
* Creates the timer.
*/
@TransactionAttribute(TransactionAttributeType.REQUIRES_NEW)
public void resetTimer()
{
if (timer != null)
{
timer.cancel();
}
timer = timerService.createTimer(30000, "Note");
}
@Override
public void readResponseMsg(Document responseXml)
{
resetTimer();
//Do stuff
}
@Override
@Timeout
public void timeout() throws RemoteException
{
//do stuff
}
}
和MDB:
@javax.ejb.MessageDriven(mappedName = "jms/MyTopic", activationConfig = {
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Topic"),
@ActivationConfigProperty(propertyName = "destination", propertyValue = "MyTopic"),
@ActivationConfigProperty(propertyName = "messagingType", propertyValue = "javax.jms.MessageListener"),
@ActivationConfigProperty(propertyName = "acknowledgeMode", propertyValue = "Auto-acknowledge") })
@ResourceAdapter("activemq.rar")
public class MyMDB implements MessageListener
{
private static final Logger ourLogger = Logger.getLogger(MyMDB.class);
@javax.ejb.EJB(mappedName="MySingletonClass") private MySingletonClassInterface reader;
/**
* @param message
*/
public void onMessage(Message message)
{
TextMessage textMessage = (TextMessage) message;
try
{
System.out.println("Received Message Text: " + textMessage.getText());
reader.readResponseMsg(loadXMLFromString(textMessage.getText()));
}
catch (JMSException | SAXException | ParserConfigurationException | IOException e)
{
ourLogger.error("Exception handling Schedule Results Message", e);
}
}
}
这是界面:
@javax.ejb.Local
public interface SomeInterface
{
public void readResponseMsg(Document responseXml);
public void timeout() throws RemoteException;
}
更新我一直在摆弄一些东西,现在看到一些例外,至少表明发生了什么事。我已经用我的更改更新了上面的代码。这是我的例外:
Caused by: javax.naming.NameNotFoundException: MySingletonClass not bound
at org.jnp.server.NamingServer.getBinding(NamingServer.java:771) [:5.0.5.Final]
at org.jnp.server.NamingServer.getBinding(NamingServer.java:779) [:5.0.5.Final]
at org.jnp.server.NamingServer.getObject(NamingServer.java:785) [:5.0.5.Final]
at org.jnp.server.NamingServer.lookup(NamingServer.java:396) [:5.0.5.Final]
at org.jnp.server.NamingServer.lookup(NamingServer.java:399) [:5.0.5.Final]
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:728) [:5.0.5.Final]
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:688) [:5.0.5.Final]
at javax.naming.InitialContext.lookup(InitialContext.java:411) [:1.7.0_25]
at org.jnp.interfaces.NamingContext.resolveLink(NamingContext.java:1350) [:5.0.5.Final]
... 61 more
此外,在JBoss 6启动日志中,我也看到了这一点:
[BeanInstantiatorDeployerBase] Installed org.jboss.ejb3.instantiator.impl.Ejb31SpecBeanInstantiator@fbda95 into MC at org.jboss.ejb.bean.instantiator/mmpl/server/MySingletonClass
然后在日志中稍微进一步:
DEPLOYMENTS MISSING DEPENDENCIES:
Deployment "jboss-switchboard:appName=mmpl,module=server,name=MyMDB" is missing the following dependencies:
Dependency "jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3" (should be in state "Installed", but is actually in state "** NOT FOUND Depends on 'jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3',whenRequired=MapControllerStateModel$ControllerStateWrapper@7ba014{Installed},dependentState=MapControllerStateModel$ControllerStateWrapper@7ba014{Installed} **")
Deployment "jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3_endpoint" is missing the following dependencies:
Dependency "jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3" (should be in state "Installed", but is actually in state "** NOT FOUND Depends on 'jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3' **")
DEPLOYMENTS IN ERROR:
Deployment "jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3" is in error due to the following reason(s): ** NOT FOUND Depends on 'jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3',whenRequired=MapControllerStateModel$ControllerStateWrapper@7ba014{Installed},dependentState=MapControllerStateModel$ControllerStateWrapper@7ba014{Installed} **, ** NOT FOUND Depends on 'jboss.j2ee:ear=mmpl.ear,jar=server.jar,name=MySingletonClass,service=EJB3' **
答案 0 :(得分:0)
我最终放弃了ejb单身人士的想法并使用了以下内容,这非常有效:
public class MySingletonClass implements SomeInterface
{
private ScheduledFuture<?> handle;
private static ScheduledExecutorService executor;
private static SomeInterface instance;
public void readResponseMsg(Document responseXml)
{
resetTimer();
//do stuff
}
/**
* Creates the timer.
*/
private void resetTimer()
{
if (handle != null)
{
handle.cancel(false);
}
handle = executor.schedule(this, 30l, TimeUnit.SECONDS);
}
/**
* Initialize the static variables. Should only be called once per server
* restart
*/
private static void init()
{
try
{
executor = Executors.newSingleThreadScheduledExecutor();
inited = true;
}
catch (Exception e)
{
ourLogger.error("Exception initializing ScheduleResultReader", e);
}
}
public static SomeInterface getInstance()
{
if (instance == null)
{
instance = new MySingletonClass();
}
return instance;
}
}