History
Andy Stanford-Clark (Overview
The MQTT protocol defines two types of network entities: a message broker and a number of clients. An MQTT broker is a server that receives all messages from the clients and then routes the messages to the appropriate destination clients. An MQTT client is any device (from a microcontroller up to a full-fledged server) that runs an MQTT library and connects to an MQTT broker over a network. Information is organized in a hierarchy of topics. When a publisher has a new item of data to distribute, it sends a control message with the data to the connected broker. The broker then distributes the information to any clients that have subscribed to that topic. The publisher does not need to have any data on the number or locations of subscribers; and subscribers, in turn, do not have to be configured with any data about the publishers. If a broker receives a message on a topic for which there are no current subscribers, the broker discards the message unless the publisher of the message designated the message as a retained message. A retained message is a normal MQTT message with the retained flag set to true. The broker stores the last retained message and the correspondingMQTT broker
The MQTT broker is a piece of software running on a computer (running on-premises or in the cloud), and could be self-built or hosted by a third party. It is available in both open source and proprietary implementations. The broker acts as a post office. MQTT clients don't use a direct connection address of the intended recipient, but use the subject line called "Topic". Anyone who subscribes receives a copy of all messages for that topic. Multiple clients can subscribe to a topic from a single broker (one to many capability), and a single client can register subscriptions to topics with multiple brokers (many to one). Each client can both produce and receive data by both publishing and subscribing, i.e. the devices can publish sensor data and still be able to receive the configuration information or control commands (MQTT is a bi-directional communication protocol). This helps in both sharing data, managing and controlling devices. A client cannot broadcast the same data to a range of topics, and must publish multiple messages to the broker, each with a single topic given. With the MQTT broker architecture, the client devices and server application become decoupled. In this way, the clients are kept unaware of each other's information. MQTT, if configured to, can use TLS encryption with certificate, username and password protected connections. Optionally, the connection may require certification, in the form of a certificate file that a client provides and must match with the server's copy. In case of failure, the broker software and clients can automatically hand over to a redundant/automatic backup broker. Backup brokers can also be set up to share the load of clients across multiple servers on site, in the cloud, or a combination of these. The broker can support both standard MQTT and MQTT for compliant specifications such as Sparkplug. This can be done with the same server, at the same time and with the same levels of security. The broker keeps track of all the session's information as the device goes on and off, in a function called "persistent sessions". In this state, a broker will store both connection info for each client, topics each client has subscribed to, and any messages for a topic with a QoS of 1 or 2. The main advantages of an MQTT broker are: # Elimination of vulnerable and insecure client connections (when appropriately configured). # Ability to easily scale from a single device to thousands. # Management and tracking of client connection states, including security credentials and certificates (when appropriately configured). # Reduction of strain on cellular or satellite networks without compromising security (when appropriately configured).Message types
Connect
Disconnect
Waits for the MQTT client to finish any work it must do, and for thePublish
Returns immediately to the application thread after passing the request to the MQTT client.Version 5.0
In 2019, OASIS released the official MQTT 5.0 standard. Version 5.0 includes the following major new features: * Reason codes: Acknowledgements now support return codes, which provide a reason for a failure. * Shared subscriptions: Allow the load to be balanced across clients, thus reducing the risk of load problems. * Message expiry: Messages can include an expiry date and are deleted if they are not delivered within this time period. * Topic alias: The name of a topic can be replaced with a single number.Quality of service
Each connection to the broker can specify a QoS measure. These are classified in increasing order of overhead: * At most once – the message is sent only once and the client and broker take no additional steps to acknowledge delivery (fire and forget). * At least once – the message is re-tried by the sender multiple times until acknowledgement is received (acknowledged delivery). * Exactly once – the sender and receiver engage in a two-level handshake to ensure only one copy of the message is received (assured delivery). This field does not affect handling of the underlying TCP data transmissions; it is only used between MQTT senders and receivers.Security
Security of the MQTT protocol was compromisedVaccari, I., Aiello, M., Cambiaso, E. (2020). SlowITe, a novel denial of service attack affecting MQTT. Sensors, 20(10), 2932. . in 2020 by Italian researchers, executing slow DoS attacks on such protocol.Clustering
MQTT clustering is a technique employed to ensure high availability, fault tolerance, and scalability in MQTT deployments. As an efficient and lightweight messaging protocol, MQTT clustering allows for the creation of a resilient network of interconnected broker nodes, ensuring continuous and reliable message delivery even in the face of hardware failures or network disruptions.See also
* Comparison of MQTT implementations * Advanced Message Queuing Protocol (AMQP) * Streaming Text Oriented Messaging Protocol (STOMP) * Constrained Application Protocol (CoAP) * Apache ActiveMQ * Solace PubSub+ * RabbitMQNotes
References
External links
* {{Authority control Application layer protocols Data transmission MQ Message-oriented middleware Network protocols Telemetry