我想在 Wildfly 11 中使用嵌入式 Apache Artemis 接收 MQTT 消息。
当前状态:
我向 Wildfly 嵌入式 Apache Artemis 添加了 MQTT 协议支持(添加了“缺失”文件夹和 artemis-mqtt-protocol-.jar 并在 module.xml 中启用了协议)
我正在使用完整的独立配置并为 MTQQ 添加了接受器:
<subsystem xmlns="urn:jboss:domain:messaging-activemq:2.0"> <server name="default"> <remote-acceptor name="mqtt-acceptor" socket-binding="mqtt"> <param name="protocols" value="MQTT"/> </remote-acceptor>
和主题为:
<jms-topic name="testEndpoint" entries="java:/jms/testEndpoint"/>
- 还将 mqtt 添加到套接字绑定
从日志中我可以看到它有效:
AMQ221020:在 127.0.0.1:1883 开始接受协议的协议 [MQTT]
AMQ221007:服务器现已上线 AMQ221001:Apache ActiveMQ Artemis 消息代理版本 1.5.5.jbossorg-008
AMQ221003:部署队列 jms.queue.DLQ
WFLYMSGAMQ0002:将消息传递对象绑定到 jndi 名称 java:/ConnectionFactory
AMQ221003:部署队列 jms.queue.ExpiryQueue
WFLYMSGAMQ0002:将消息传递对象绑定到 jndi 名称 java:jboss/exported/jms/RemoteConnectionFactory
AMQ221052:部署主题 jms.topic.testEndpoint
- 接下来我写了一个简单的MDB:
@MessageDriven(
activationConfig = { @ActivationConfigProperty(propertyName = "destination",
propertyValue = "testEndpoint"),
@ActivationConfigProperty(propertyName = "destinationType",
propertyValue = "javax.jms.Topic")
},
mappedName = "testEndpoint")
public class TestEndpoint implements MessageListener {
private static final Logger logger = Logger.getLogger(TestEndpoint.class.getName());
public void onMessage(Message message) {
try {
logger.debug("message: " + message.getClass().getName());
} catch (Exception e) {
logger.debug("exception: " + e.getMessage());
}
}
}
- 我可以在端口 1883 上连接到服务器,当我向 testEndpoint 发送消息时,我可以在日志中看到:
会话创建:63f14f85-0fa2-4fe7-a27b-03ef8e6639a2
在 message=ServerMessage[messageID=962,durable=true,userID=null,priority=0,bodySize=512,timestamp=0,expiration=0,durable=true,address=testEndpoint 上找不到地址=testEndpoint 的任何绑定,properties=TypedProperties[mqtt.message.retain=true,mqtt.qos.level=1]]@749653273
Message ServerMessage[messageID=962,durable=true,userID=null,priority=0, bodySize=512, timestamp=0,expiration=0,durable=true, address=testEndpoint,properties=TypedProperties[mqtt.message.retain=true ,mqtt.qos.level=1]]@749653273 不会去任何地方,因为它没有绑定地址:testEndpoint
QueueImpl[name=$sys.mqtt.retain.testEndpoint, postOffice=PostOfficeImpl [server=ActiveMQServerImpl::serverUUID=c58c74d5-ea71-11e7-9621-a434d929f4aa]]@6ff93fb4 正在交付。消息参考=0
所以看起来我在某处缺少一些绑定,但我找不到它会是什么。有人有什么想法吗?