Forward to and from HiveMQ
Tutorial to configure FairCom's MQTT broker engine to forward messages to and from a HiveMQ broker
The MQTT broker in FairCom MQ and FairCom Edge can act as a bridge to another MQTT broker. You can use the API Explorer tool to configure FairCom's MQTT broker engine.
Note
You can chain together MQTT brokers by forwarding messages from one broker to another. This is a great way to move information across data centers, factories, and clouds. (See Broker forwarding.)
The MQTT broker in FairCom MQ and FairCom Edge can act as a bridge to another MQTT broker. You can use the API Explorer tool to configure FairCom's MQTT broker engine.
This tutorial contains detailed instructions for configuring FairCom's MQTT broker engine to forward messages to a HiveMQ broker. Messages published to FairCom's MQTT broker engine on one port will be forwarded to the HiveMQ broker running on a different port. HiveMQ broker subscribers will then receive the messages.
Ensure FairCom MQ is downloaded and installed.
Confirm server access by running the FairCom API Explorer (see API Explorer to learn about the user interface).
Ensure HiveMQ is downloaded and installed.
Complete the tutorial requirements before this procedure.
Important
HiveMQ and FairCom MQ must be on different ports.
The default port for both FairCom MQ and HiveMQ is 1883
.
In this procedure, HiveMQ will be listening on port 1884
, and FairCom MQ will be on 1883
. The port number does not matter as long as they are open ports. Similarly, the configuration file name does not matter.
Navigate to the
configure
folder typically namedconf
, in the unpackedHiveMQ
folder.Locate and open the
Config XML
file inside theconf
folder with your preferred text editor.Verify the listening port is
<port>1884</port>
.Verify that
anonymous-usage-statistics
is set totrue
.<anonymous-usage-statistics> <enabled>true</enabled> </anonymous-usage-statistics>
Start the HiveMQ broker.
Navigate back to the parent directory where the
bin
folder is located.Run the
run.bat
file.
In this procedure, the API Explorer is used to configure a broker connection and configure a topic, in that order.
Select MQ API from the Select API dropdown menu.
Select the
"configureBrokerConnection"
action from the JSON Actions dropdown menu.Replace the JSON in the API Request editor with the following JSON:
{ "api": "mq", "apiVersion": "1.0", "requestId": "00000015", "authToken": "aAuthTokenProvidedByTheServer", "action": "configureBrokerConnection", "params": { "brokerConnectionName": "HiveMQConnection", "brokerHostname": "127.0.0.1", "brokerPort": "1884" } }
Click Apply defaults to JSON request () to replace the
"authToken"
value with the valid one from your session.Click Send request ().
Observe the response and ensure the action completed successfully.
Note
"errorCode"
with a value of0
indicates success."errorCode"
with a non-zero value indicates a failure, see Errors and contact FairCom with any questions.{ "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "result": {}, "requestId": "00000015", "debugInfo": { "request": { "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "api": "mq", "action": "configureBrokerConnection", "params": { "brokerConnectionName": "HiveMQConnection", "brokerHostname": "127.0.0.1", "brokerPort": "1884" }, "apiVersion": "1.0", "requestId": "00000016", "debug": "max" } }, "errorCode": 0, "errorMessage": "" }
Select the
"listBrokerConnection"
action from the JSON Actions dropdown menu.Click Send request ().
Observe the list of
"brokerConnectionNames"
in the response to verify"HiveMQConnection"
was created.{ "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "result": { "brokerConnectionNames": [ "HiveMQConnection", "MosqBroker" ] }, "requestId": "00000018", "debugInfo": { "request": { "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "api": "mq", "action": "listBrokerConnections", "apiVersion": "1.0", "requestId": "00000018", "debug": "max" } }, "errorCode": 0, "errorMessage": "" }
Select the
"configureTopic"
action from the JSON Actions dropdown menu.Replace the JSON in the API Request editor with the following JSON:
Note
The
"params.topic"
value is the MQTT topic that receives inbound messages.The
"params.forwardToExternalBroker.[].topic"
value is the topic on the target broker that will receive the MQTT topic messages.
{ "api": "mq", "apiVersion": "1.0", "requestId": "00000001", "authToken": "anAuthTokenProvidedByServer", "action": "configureTopic", "params": { "topic": "house", "forwardToExternalBroker": [ { "brokerConnectionName": "HiveMQConnection", "topic": "house" } ] } }
Click Apply defaults to JSON request () to replace the
"authToken"
value with the valid one from your session.Click Send request ().
Observe the response and ensure the action completed successfully.
Note
"errorCode"
with a value of0
indicates success."errorCode"
with a non-zero value indicates a failure, see Errors and contact FairCom with any questions.{ "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "result": {}, "requestId": "00000019", "debugInfo": { "request": { "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "api": "mq", "action": "configureTopic", "params": { "topic": "house", "forwardToExternalBroker": [ { "brokerConnectionName": "HiveMQConnection", "topic": "house" } ] }, "apiVersion": "1.0", "requestId": "00000019", "debug": "max" } }, "errorCode": 0, "errorMessage": "" }
Select the
"configureTopic"
action from the JSON Actions dropdown menu.Replace the JSON in the API Request editor with the following JSON:
{ "authToken": "authTokenHere", "api": "mq", "action": "configureTopic", "params": { "topic": "house", "subscribeToExternalBroker": "HiveMQConnection" } }
Click Apply defaults to JSON request () to replace the
"authToken"
value with the valid one from your session.Click Send request ().
Observe the response and ensure the action completed successfully.
Note
"errorCode"
with a value of0
indicates success."errorCode"
with a non-zero value indicates a failure, see Errors and contact FairCom with any questions.{ "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "result": {}, "requestId": "00000020", "debugInfo": { "request": { "authToken": "PqxlwypHN8h7KHL2yVotMjCEj7dl0MdCyFRu6LEs59bsJy6EH6XEOaOHHxKVyyOp", "api": "mq", "action": "configureTopic", "params": { "topic": "house", "subscribeToExternalBroker": "HiveMQConnection" }, "requestId": "00000020", "debug": "max" } }, "errorCode": 0, "errorMessage": "" }
This procedure will subscribe you to all messages on a topic house, on port 1884
, the port that HiveMQ is listening on.
Navigate to the
python.mqtt
directory in<faircom>/drivers/python.mqtt/PythonMQTTTutorial1/subscribe
to use one of FairCom's drivers.Run the python subscribe.py -t house -s 127.0.0.1:1884 command.
This tutorial uses the python.mqtt
driver. For more information on this driver, see MQTT client for Python.
Navigate to and open the
python.mqtt
directory through<faircom>/drivers/python.mqtt/PythonMQTTTutorial1/publish
to use one of FairCom's drivers.Run the python publish.py -t house -f data.json command, to publish a JSON object to port
1883
.Observe that the published JSON sample, contained in the driver package, has been successfully received by the HiveMQ subscriber client.