MQTT (Message Queue Telemetry Transport) is a lightweight publish-subscribe messaging protocol.
In order to connect to a MQTT broker, the mqtt-rar-0.8.0.rar
has to be deployed as shown in the Installing a connector section of the Cloud Connectors overview.
In order to make use of this connector in an application, the following Maven dependency is needed:
<dependency>
<groupId>fish.payara.cloud.connectors.MQTT</groupId>
<artifactId>mqtt-jca-api</artifactId>
<version>0.8.0</version>
<type>jar</type>
<scope>provided</scope>
</dependency>
Note that this dependency have scope provided since the types within this dependency are globally available to every application deployed to Payara Micro after the mqtt-rar-0.8.0.rar
was deployed.
Sending messages
Sending messages to a MQTT broker can be done via the JCA and an MQTT specific API. In order to start using this API to send messages, a resource has to be defined via the JCA API; a connection factory.
The connection factory has to be given a name, which can be any name that is valid for JNDI. The java:app
namespace is typically recommended to be used. The type of the connection factory to be used for MQTT is fish.payara.cloud.connectors.MQTT.api.MQTTConnectionFactory
, and we have to specify the resource adapter name which is here mqtt-rar-0.8.0.rar
.
The following gives an example:
@ConnectionFactoryDefinition (
name = "java:app/MQTT/factory",
interfaceName = "fish.payara.cloud.connectors.MQTT.api.MQTTConnectionFactory",
resourceAdapter = "mqtt-rar-0.8.0"
properties = "cleanSession=true"
)
With the above shown definition in place the following code shows an example of sending a message:
@Singleton
@Startup
public class SendMQTTMessage {
@Resource(lookup = "java:app/MQTT/factory")
private MQTTConnectionFactory factory;
@PostConstruct
public void init() {
try (MQTTConnection connection = factory.createConnection()) {
connection.publish("test", "{\"test\": \"Hello World\"}".getBytes(), 0, false);
}
catch (Exception ex) {
}
}
}
Receiving messages
Messages can be received from an MQTT broker by creating an MDB (Message Driven Bean) that implements the fish.payara.cloud.connectors.MQTT.api.MQTTListener
marker interface and has a single method annotated with @OnMQTTMessage
and the method signature void method(String topic, MqttMessage message)
.
The following gives an example:
@MessageDriven(activationConfig = {
@ActivationConfigProperty(propertyName = "topicFilter", propertyValue = "test")
})
public class ReceiveMQTTMessage implements MQTTListener {
@OnMQTTMessage
public void receiveMessage(String topic, MqttMessage message) {
// Handle message
}
}
Config Property Name | Type | Default | Notes |
---|---|---|---|
|
String |
tcp://localhost:1883 |
Server URIs for connection, comma separated |
|
Boolean |
false |
Sets whether the client and server should remember state across reconnects |
|
Boolean |
true |
Sets whether the client will automatically reconnect to the server if the connection is lost |
|
Boolean |
false |
Whether the client should use file persistence for un-acknowledged messages |
|
String |
. |
Directory to use for file persistence |
|
Integer |
30 |
Sets the connection timeout value in seconds |
|
Integer |
10 |
Sets the maximum messages that can be sent without acknowledgements |
|
Integer |
60 |
Sets the keep alive interval in seconds |
|
String |
None |
The username for the connection. |
|
String |
None |
The password for the connection. |
|
String |
None |
Topic Filter (For MDBs only) |
|
String |
0 |
Quality of Service for the subscription (For MDBs only) |