我要问的问题以前在这里问过。David Ingham 背诵了这个 Microsoft Document给出了答案。Sentinel 已确认该解决方案有效。
然而,我有同样的问题。我按照微软的文档来信,但是,仍然有同样的问题。
存在冗余的风险,问题是当使用 Qpid-JMS 客户端库(版本 0.22 或 0.26)连接到Windows Server(不是 Azure)上的服务总线(1.1)并遵循 Microsoft 的所有指示时,包括
- 生成 RootCA 证书并将其应用于 Java 信任库
- 使用您的 Windows 登录用户/密码
- 使用 amqps://[user]:[pwd]@FQDN/[namespace] 连接工厂字符串
- 使用 [namespace]/[queuename] 作为您的物理队列名称。
上下文查找、连接创建、会话创建都可以正常工作。但是,当需要创建 MessageProducer 或 MessageConsumer 时,我会遇到错误。
对于 MessageProducer 创建(不管是队列还是主题),我总是得到
Caused by: org.apache.qpid.amqp_1_0.client.Sender$SenderCreationException:
Peer did not create remote endpoint for link, target: testns/testq1
at org.apache.qpid.amqp_1_0.client.Sender.<init>(Sender.java:171)
对于 MessageConsumer 创建我得到
javax.jms.JMSException
at org.apache.qpid.amqp_1_0.jms.impl.MessageConsumerImpl.createClientReceiver(MessageConsumerImpl.java:164)
at org.apache.qpid.amqp_1_0.jms.impl.MessageConsumerImpl.<init>(MessageConsumerImpl.java:120)
这是我尝试过的几件事。
- 我的服务总线安装在 Windows 2012 Server 上。我的客户端从另一个 Windows 2012 Server 运行。但是我也将客户端移到了运行服务总线的服务器上,但没有解决方案。(所以这不是位置问题)
- 当我从信任库中取出证书时,我收到了一个适当的错误。当我把它插回去时,错误就消失了。(所以这不是证书问题)
- 当我故意拼错我的 Windows 用户名或密码时,我会收到身份验证错误。否则错误消失。(所以这不是用户/密码问题)
- 似乎我在连接字符串中显式键入端口号 5671 并不重要。在任何一种情况下,连接创建都可以正常工作。(所以这不是连接问题)
- 在连接字符串或队列定义中定义命名空间似乎无关紧要。在这两种情况下都失败了。
- 我已经下载了 Qpid-JMS-Client (0.22) 的源代码并单步调试。目标(要连接的队列的地址)在创建连接时设置正确,但在离开同步块后立即重置为 null,这会导致错误(在 MessageProducer 的情况下)
我从原始 Microsoft 文档中遗漏了什么(由名为 Sentinel 的用户确认它有效)?
任何帮助将不胜感激。谢谢你,-Dogan Atay