我在以下设置中遇到问题:
Java 应用程序将电子邮件消息发送到 JMS 队列,然后侦听队列的 MDB 使用 onMessage 方法获取电子邮件消息,它打开 Gmail SMTP 上的连接,将电子邮件发送到 SMTP 并关闭连接。对 JMS 队列中的所有消息执行此操作。
当我在队列中同时有多达 5 条消息时,它工作得很好。所有邮件都由 5 个不同的 MDB 实例同时接收,因此我有 5 个并发连接到 Gmail SMTP 服务器。但是当 JMS 队列中有更多邮件时,我从 Gmail SMTP 服务器收到连接错误。前 5 条消息正确发送,但其余消息未正确发送,因此其他消息丢失,因为它们不再在队列中。
所以我的问题是,是否可以限制将侦听 JMS 队列的 MDB 实例的数量?如果我最多有 5 个 MDB,那么即使队列中有 1000 条消息,清空队列也需要更长的时间,但至少我不会丢失任何消息。
任何其他解决此问题的建议将不胜感激。
这是Jboss版本:
[Server] Release ID: JBoss [Trinity] 4.2.3.GA (build: SVNTag=JBoss_4_2_3_GA date=200807181417)
MDB的配置如下:
@MessageDriven(activationConfig = {
@ActivationConfigProperty( propertyName = "destinationType", propertyValue = "javax.jms.Queue" ),
@ActivationConfigProperty( propertyName = "destination", propertyValue = "queue/emailQueue")
})
你需要更多吗?
谢谢
编辑 2011-02-14
也许我想限制 MDB 实例的数量是错误的。我看到了一个关于 JMS 线程数的配置。如果我限制将发布到 MDB 的线程数,也许它会解决我的问题?JMS 会等到 MDB 可用后再发布 msg 吗?这样做有什么副作用吗?你虽然请。谢谢
结束编辑