|  | Home | Libraries | People | FAQ | More | 
      The mqtt_clientmqtt_clientPINGREQ to the Broker to maintain
      a stable connection.
    
      The proper way to stop the mqtt_clientmqtt_client::cancel
      or mqtt_client::async_disconnect.
      Invoking mqtt_client::cancel
      results in the mqtt_clientmqtt_client::async_disconnect
      will first attempt to send a DISCONNECT packet [4] to the Broker to notify it about the reason for disconnection,
      then close the connection and cancel all outstanding asynchronous operations
      (equal effect as mqtt_client::cancel).
    
| ![[Important]](../../../../../doc/src/images/important.png) | Important | 
|---|---|
| 
        Regardless of the method used to stop the  | 
      Invoking mqtt_client::cancel
      or mqtt_client::async_disconnect
      will result in a clean and graceful shutdown process. This ensures that all
      resources are properly released and all asynchronous operations are completed
      [5]. Consequently, the execution context (boost::asio::io_context)
      will stop due to a lack of work.
    
| ![[Note]](../../../../../doc/src/images/note.png) | Note | 
|---|---|
| 
        The  | 
      The following code snippet will showcase a scenario of disconnecting the mqtt_client
      The following code snippet is an example of publishing a "Hello World!"
      message to the Broker with QoS 0,
      followed by the request to disconnect the mqtt_client
int main() { boost::asio::io_context ioc; boost::mqtt5::mqtt_client<boost::asio::ip::tcp::socket> client(ioc); client.brokers("<your-mqtt-broker>", 1883) .async_run(boost::asio::detached); client.async_publish<boost::mqtt5::qos_e::at_most_once>( "<topic>", "Hello world!", boost::mqtt5::retain_e::no, boost::mqtt5::publish_props {}, [](boost::mqtt5::error_code ec) { std::cout << ec.message() << std::endl; } ); client.async_disconnect(boost::asio::detached); ioc.run(); }
      Suppose the Broker is available and the mqtt_client
DISCONNECT packet with Reason
          Code 0x00 (Normal
          Disconnection).
        
      It is important to note that the PUBLISH packet containing the "Hello
      World!" message will not be transmitted. As outlined in the Packet Ordering
      in Optimising communication
      section, mqtt_client::async_publish
      and mqtt_client::async_disconnect
      will place their corresponding packets in the queue. However, DISCONNECT packets are prioritised
      and sent exclusively, ahead of other queued packets. Therefore, the connection
      will terminate immediately.
    
      If the mqtt_client5
      seconds, which is the amount of time
      it will spend trying to send the DISCONNECT packet to the Broker before
      quitting. This timeout mechanism ensures that the mqtt_client
      In this case, the proper way to disconnect would be to call mqtt_client::async_disconnect
      after the mqtt_client::async_publish
      has been completed.
    
client.async_publish<boost::mqtt5::qos_e::at_most_once>( "<topic>", "Hello world!", boost::mqtt5::retain_e::no, boost::mqtt5::publish_props {}, [&client](boost::mqtt5::error_code ec) { std::cout << ec.message() << std::endl; client.async_disconnect(boost::asio::detached); } );
        Once the mqtt_clientmqtt_client::async_run.
        This method can be called right after initiating mqtt_client::async_disconnect,
        without waiting for it to complete.
      
        The mqtt_client
int main() { boost::asio::io_context ioc; boost::mqtt5::mqtt_client<boost::asio::ip::tcp::socket> client(ioc); client.brokers("<your-mqtt-broker>", 1883) .async_run(boost::asio::detached); client.async_disconnect(boost::asio::detached); // The Client can be reconfigured again. client.connect_property(boost::mqtt5::prop::session_expiry_interval, 120) .keep_alive(30) .async_run(boost::asio::detached); // Restart the Client again. // Use the Client... ioc.run(); }
[4] 
        The mqtt_clientDISCONNECT packet for 5 seconds.
        Regardless of the outcome, the connection will be closed.
      
[5] 
        All outstanding operations will complete with error code boost::asio::error::operation_aborted.