IoT Application Service
The function blocks included in this library communicate via MQTT protocol with the IBM Watson IoT Platform which acts as a broker. A secured connection (SSL/TLS) to the IBM IoT Platform is built by the client. The necessary parameters are defined in the device configuration. The objects are communicated as secured json strings.
data:image/s3,"s3://crabby-images/8853b/8853ba84eed5d7a242e61b1d33efecdcb212dccd" alt=""
Available Function Blocks
Elements and functionality of the MQTT protocol
Client: |
MQTT clients can be different devices or applications, which are able to send and receive MQTT messages. These clients are not interconnected, as they communicate over a broker with each other. Examples of such client devices are sensors, controllers, smartphones and other devices, which can run a MQTT library. In general, clients can be publisher and subscriber at the same time. |
Broker: |
The broker is a central server, which receives the sent message of the publisher and forwards it to all receivers (subscribers) that have a subscription for this topic. Example: If the broker receives a message with a temperature value from a temperature sensor in a building, it publishes the message to all receivers that subscribed to the topic with the temperature value. |
Message: |
The message contains the topic and the actual user data, and is sent from the publisher via broker to the subscriber. |
Publish: |
Describes the sending of a message by a client, triggered by a certain event. |
Subscribe: |
Describes the registration for the receiving of messages, which contain a certain topic. NOTE: In general, the MQTT protocol allows the usage of wildcards (# und +) for the subscription of topics. However, the described function blocks in this document do NOT support this feature. |
Topic: |
The topic is a text that represents a hierarchy, using a slash (/) as a separator. It stands for the subject of the message: Normally the structure looks like that: >heater/office/upstairs/temperaturesensor/1< However, such hierarchy is NOT applicable for function blocks in connection with the IBM Watson IoT Platform. |
Quality of Service (QoS) |
QoS contains 3 Levels.
|
data:image/s3,"s3://crabby-images/e4042/e404204f7012ef4baff7af61ee7090fbf02ebe8a" alt=""
If events cannot be published (interrupted connection), they are buffered. That is accomplished by following two steps:
- If the connection is re-established during the defined “keepAlive” cycle, the events which were kept in the memory are published as quickly as possible.
- If the connection is interrupted longer than with the defined period of the “keepAlive” cycle, the events are buffered in a database. If the connection is established again, the content of the database is published as quickly as possible.