Java DefaultMessageListenerContainer未停止
我将SpringJMS与以下上下文XML文件一起使用Java DefaultMessageListenerContainer未停止,java,spring,jms,Java,Spring,Jms,我将SpringJMS与以下上下文XML文件一起使用 <bean id="connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory" p:brokerURL="tcp://localhost:61616" /> <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFa
<bean id="connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"
p:brokerURL="tcp://localhost:61616" />
<bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop"
p:connectionFactory-ref="connectionFactory" />
<bean id="queue1" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg value="foo.bar"/>
</bean>
<bean id="listenerContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer" destroy-method="destroy"
p:autoStartup="true"
p:connectionFactory-ref="pooledConnectionFactory"
p:destination-ref="queue1"
p:messageListener-ref="listener"
p:acceptMessagesWhileStopping="false"
p:sessionTransacted="true" />
这里的问题是,当主线程结束时,进程不会停止。我目前猜测侦听器容器没有停止
这是末尾的日志消息:
16:54:02,747 DEBUG [main] DefaultListableBeanFactory:246 - Returning cached instance of singleton bean 'app'
16:54:02,747 INFO [main] App:47 - Terminating...
16:54:02,747 INFO [main] App:51 - Terminated.
16:54:02,771 DEBUG [listenerContainer-1] TaskRunnerFactory:91 - Initialized TaskRunnerFactory[ActiveMQ Session Task] using ExecutorService: java.util.concurrent.ThreadPoolExecutor@6c63a721
16:54:03,783 DEBUG [listenerContainer-1] ActiveMQSession:559 - ID:Daniels-MacBook-Pro.local-56179-1359680042616-1:1:1 Transaction Commit :null
16:54:04,784 DEBUG [listenerContainer-1] ActiveMQSession:559 - ID:Daniels-MacBook-Pro.local-56179-1359680042616-1:1:1 Transaction Commit :null
16:54:05,785 DEBUG [listenerContainer-1] ActiveMQSession:559 - ID:Daniels-MacBook-Pro.local-56179-1359680042616-1:1:1 Transaction Commit :null
16:54:06,787 DEBUG [listenerContainer-1] ActiveMQSession:559 - ID:Daniels-MacBook-Pro.local-56179-1359680042616-1:1:1 Transaction Commit :null
16:54:07,788 DEBUG [listenerContainer-1] ActiveMQSession:559 - ID:Daniels-MacBook-Pro.local-56179-1359680042616-1:1:1 Transaction Commit :null
...
仅供参考,我试图关闭自动启动(通过设置p:autoStartup=“false”
)并手动启动/停止代码中的容器,但是,它也不起作用。在退出之前,请先打开stop()
上下文:
public static void main(String[] args) throws JMSException, InterruptedException {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("my- context.xml");
context.registerShutdownHook();
App app = context.getBean("app", App.class);
app.start();
context.stop();
}
我通过在末尾添加
context.close()
call解决了这个问题
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("my-context.xml");
context.registerShutdownHook();
App app = context.getBean("app", App.class);
app.start();
context.close();
}
我离开了context.registerShutdownHook()调用,以防应用程序在外部关闭(如Ctrl+C
)
我做得对吗?不,它不起作用。另外,我已经调用了
context.registerShutdownHook()
。
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("my-context.xml");
context.registerShutdownHook();
App app = context.getBean("app", App.class);
app.start();
context.close();
}