日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java消息失败重发_JMS消息在JMS侦听器中重新发送异常

發布時間:2025/3/12 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java消息失败重发_JMS消息在JMS侦听器中重新发送异常 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Javadoc為 org.springframework.jms.listener.AbstractMessageListenerContainer 表示,如果

“sessionAcknowledgeMode”設置為“CLIENT_ACKNOWLEDGE”:成功偵聽器執行后自動確認消息;如果拋出異常,則無法重新發送 .

我猜,“在拋出異常的情況下沒有重新傳遞”意味著,即使jms監聽器中拋出異常,該消息也不會被重新傳遞(因此,我的猜測,它會得到確認) . 但是,從偵聽器拋出的異常意味著對它的調用不成功,并且由于沒有確認應該重新發送 .

問題是:

What actually should happen with message acknowledgement in case of exception thrown in the jms listener?

從這個堆棧跟蹤中可以看到真正發生的事情:

at org.springframework.jms.listener.adapter.MessagingMessageListenerAdapter.invokeHandler(MessagingMessageListenerAdapter.java:98)

at org.springframework.jms.listener.adapter.MessagingMessageListenerAdapter.onMessage(MessagingMessageListenerAdapter.java:66)

at org.springframework.jms.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:660)

at org.springframework.jms.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:620)

at org.springframework.jms.listener.AbstractMessageListenerContainer.doExecuteListener(AbstractMessageListenerContainer.java:591)

at org.springframework.jms.listener.AbstractPollingMessageListenerContainer.doReceiveAndExecute(AbstractPollingMessageListenerContainer.java:308)

at org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveAndExecute(AbstractPollingMessageListenerContainer.java:246)

at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.invokeListener(DefaultMessageListenerContainer.java:1142)

at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.executeOngoingLoop(DefaultMessageListenerContainer.java:1134)

at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:1031)

堆棧跟蹤的第5行是特別感興趣的 . 那里的代碼基本上意味著,(大多數情況下)從偵聽器拋出的任何異常都將繞過在 org.springframework.jms.listener.AbstractMessageListenerContainer#commitIfNecessary 中完成的確認 .

That's ok, but what does "no redelivery in case of exception thrown" mean then?

附加信息:

spring JMS:4.1.2

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的java消息失败重发_JMS消息在JMS侦听器中重新发送异常的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。