|  | Home | Libraries | People | FAQ | More | 
      The auto-reconnect and retry mechanism is a key feature of the Boost.MQTT5
      library. It is designed to internally manage the complexities of disconnects,
      backoffs, reconnections, and message retransmissions. These tasks, if handled
      manually, could lead to extended development times, difficult testing, and
      compromised reliability. By automating these processes, the Boost.MQTT5
      library enables users of the mqtt_client
      You can call any asynchronous function within the mqtt_clientmqtt_clientmqtt_client
      The following example will showcase how the mqtt_clientmqtt_clientmqtt_client::async_publish,
      mqtt_client::async_subscribe,
      mqtt_client::async_unsubscribe,
      and mqtt_client::async_disconnect).
    
// Publishing with QoS 1 involves a two-step process: sending a PUBLISH message to the Broker and awaiting a PUBACK (acknowledgement) response. // The scenarios that might happen are: // 1) The Client will immediately send the PUBLISH message and start to wait for the PUBACK reply. // The user's completion handler will not be invoked yet, regardless of whether the Client successfully sent the message. // 2) When the Client fails to send the message, it will try to reconnect to the Broker automatically. // If it succeeds, it will resend the message. If reconnect fails, the Client will try to connect again until it succeeds. // Meanwhile, the user's completion handler will NOT be invoked except when the Client detects an unrecoverable error (for example, when the list of configured brokers is empty). // Note that the Client will try to connect indefinitely, meaning the user's completion handler may never be invoked. // 3) When the Client successfully sends the PUBLISH message, the Broker is required to respond with a PUBACK message. // The reply message may indicate success or an MQTT error (for example, signalling that the message is not accepted due to implementation or administrative limits). // The Client will read the PUBACK message and call the user's completion handler with the appropriate arguments. // 4) The PUBACK message should arrive within 20 seconds of the PUBLISH message being successfully sent. // If it does not, the PUBLISH message will be sent again. In the meantime, the user's callback will not be invoked. client.async_publish<boost::mqtt5::qos_e::at_least_once>( "my-topic", "Hello world!", boost::mqtt5::retain_e::no, boost::mqtt5::publish_props {}, [](boost::mqtt5::error_code ec, boost::mqtt5::reason_code rc, boost::mqtt5::puback_props props) { // This callback is invoked under any of the following circumstances: // a) The Client successfully sends the PUBLISH packet and receives a PUBACK from the Broker. // b) The Client encounters a non-recoverable error, such as a cancellation or providing invalid parameters // to async_publish, which prevents the message from being sent. } );
The integrated auto-reconnect and retry mechanism greatly improves the user experience by simplifying complex processes and ensuring continuous connections. However, it is important to be mindful of certain limitations and considerations associated with this feature.
        During extended periods of mqtt_clientmqtt_client::async_publish,
        may face considerable delays before invocation. This can result in users
        being left in the dark regarding the status of their requests due to the
        absence of prompt feedback on the initiated actions.
      
        The mqtt_client
        However, the connection may be closed (or never established) for other reasons,
        which are typically related to misconfiguration of broker IPs, ports, expired
        or incorrect TLS, or MQTT-related errors, such as trying to communicate with
        a Broker that does not support MQTT 5. In these cases, the mqtt_client
        The most challenging problem here is that users of the mqtt_clientmqtt_clientmqtt_client::async_publish
        callback will never be invoked, and you will not "catch" the error
        or detect the root cause of the issue.
      
        The possible alternative approach, where the mqtt_clientmqtt_clientmqtt_client::async_publish
        method. Now, the expired TLS certificate on the Broker is most probably a
        temporary issue, so it is natural that the mqtt_clientmqtt_client
        By design, one of the main functional requirements of the mqtt_client
        The proposed approach for detecting configuration errors in the mqtt_client
        The mqtt_client