Contents
In this sample, the Output Adapter for MQTT Client Subscribe and Input Adapter for MQTT Client Publish are used together to subscribe to and send data to an MQTT broker. The sample will initially subscribe to three message queues (Streambase0, Streambase1, Streambase2), each corresponding to their quality of service number.
The sample server configuration file in this sample contains connection information that is shared between the subscribe and publish adapters. This demo uses the open Eclipse iot.eclipse.org MQTT sandbox server. Please see http://iot.eclipse.org/sandbox.html for further details about this server.
In StreamBase Studio, import this sample with the following steps:
- 
                           From the top-level menu, select >. 
- 
                           Enter mqttto narrow the list of options.
- 
                           Select MQTT client publish and subscribe adapters from the StreamBase Messaging Adapters category. 
- 
                           Click . 
StreamBase Studio creates a single project containing the sample files.
- 
                           In the Project Explorer view, open the sample you just loaded. If you see red marks on a project folder, wait a moment for the project to load its features. If the red marks do not resolve themselves after a minute, select the project, right-click, and select > from the context menu. 
- 
                           Open the src/main/eventflow/folder.packageName
- 
                           Open the demo.sbappfile and click the Run button. This opens the SB Test/Debug perspective and starts the module. Run button. This opens the SB Test/Debug perspective and starts the module.
- 
                           Select the PublishDataStream in the Manual Input window.Enter the following values: - 
                                    Topic: Streambase2 
- 
                                    Payload: This is a test message 
- 
                                    Qos: 2 
- 
                                    Advanced: null 
 and click the Send Data button. 
- 
                                    
- 
                           Repeat this step, sending messages to the various message queues. Note that Qos can only be set as high as the message queue default allows. For example, you cannot send a Qos level 2 message to Streambase0 because that message queue was set up to only handle Qos level 0 messages. 
- 
                           In the Output Streams view, observe tuples emitted on the PublishStatusandDataoutput streams.
- 
                           Select individual tuples emitted from the PublishStatusandDatastreams, to analyze and understand their structure.
- 
                           When done, press F9 or click the  Terminate EventFlow Fragment button. Terminate EventFlow Fragment button.
It is important to note that MQTT requires various settings in order to set up persistent connections:
- 
                           A ClientIdset in thesrc/main/configurations/MQTT.confconnection settings file. If left blank, a default is used, and persistence will not service program restarts.
- 
                           The isCleanSessionsetting must be set to false in the connection settings file.
- 
                           The manualAckssetting must be set to true.
- 
                           Messages must be set to QoS level 2. 
- 
                           Messages must be ACKed by the MQTTClientAck adapter or they will be assumed to be undelivered and delivered during the next connection (this sample demonstrates this). 
- 
                           If you plan to stop your running process and restart, change PersistenceTypetofilein the settings file to maintain state across program restarts.
To run the sample, do the following:
- 
                           Continuing in the same sample project, open the DemoManualAck.sbappfile.
- 
                           Click the  Run button. This opens the SB Test/Debug perspective and starts the module. Run button. This opens the SB Test/Debug perspective and starts the module.
- 
                           This sample automatically connects to the iot.eclipse.orgMQTT broker and sends five messages to the channel, StreambaseAck. The MQTT Client Subscribe adapter acknowledges three of the five and then disconnect, reconnect, and acknowledges the remaining two.
- 
                           In the Output Streams view, observe tuples emitted on the PublishStatusandDataoutput streams.
- 
                           When done, press F9 or click the  Terminate EventFlow Fragment button. Terminate EventFlow Fragment button.
When you load the sample into StreamBase® Studio, Studio copies the sample project's files to your Studio workspace, which is normally part of your home directory, with full access rights.
Important
Load this sample in StreamBase® Studio, and thereafter use the Studio workspace copy of the sample to run and test it, even when running from the command prompt.
Using the workspace copy of the sample avoids permission problems. The default workspace location for this sample is:
studio-workspace/sample_adapter_embedded_mqtt-clientSee Default Installation Directories for the default location of studio-workspace on your system.
                  
