Overcoming Address Change with MQTT over QUIC
Introduction
In this post, we will provide an overview of MQTT over QUIC and explain what happens when a TCP client encounters address migration. We will then compare this with the behavior exhibited by the QUIC protocol.
MQTT over TCP: Challenges of Network Address Change
When using MQTT over TCP, network address change refers to a situation where the client's IP address changes during an active connection. This can occur due to various reasons, such as a device moving between networks, switching from Wi-Fi to cellular data, or experiencing network disruptions.
Network address change in TCP-based MQTT connections presents challenges and may result in connection drops and re-establishment. Address changes in client source addresses are particularly common in modern mobile networks. Mobile devices frequently switch between different network types, such as Wi-Fi, 4G, or 5G, as they move or encounter varying network conditions.
This dynamic behavior adds an extra layer of complexity to MQTT over TCP connections. Additionally, address migration events can put an extra load on the MQTT broker, making it difficult to plan hardware resources efficiently. Sudden bursts of reconnections due to address changes can strain the MQTT broker's capacity and affect its performance. Ensuring that the MQTT broker can handle a high volume of reconnection requests becomes a crucial consideration in such scenarios. Furthermore, from a development perspective, simulating client source address changes in a test environment is not a trivial task. It often requires specialized tools and configurations to mimic the dynamic nature of mobile networks accurately. This complexity makes it challenging for developers to thoroughly test the behavior and robustness of their MQTT applications in the face of the network address change.
MQTT over QUIC: A Better Solution to Address Change Scenarios
MQTT over QUIC provides a more efficient solution for tackling the obstacles of address change compared to MQTT over TCP. The QUIC protocol is designed to handle network changes seamlessly, providing enhanced resilience.
By leveraging QUIC transport, the following benefits can be observed:
Address Migration Resilience: QUIC enables clients to migrate their IP addresses seamlessly, minimizing disruptions in the MQTT connection. The burden of reconnection attempts and session re-establishment due to address changes is significantly reduced.
Reduced Load on MQTT Broker: The ability of MQTT over QUIC to handle address change more efficiently alleviates the load on the MQTT broker. The MQTT broker can better manage resource allocation and scaling plans, taking into account the reduced impact of sudden bursts of reconnections.
Development Simplicity: MQTT over QUIC simplifies the development and testing process by providing built-in support for address migration. Developers can focus more on the application logic and functionality without worrying extensively about simulating address changes during testing.
By adopting MQTT over QUIC, IoT applications can benefit from improved scalability, reduced load on the MQTT broker, and simplified development and testing processes in the presence of client source address changes.
Demo: Address/Connection Migration in MQTT over QUIC
In this chapter, we will walk you through a step-by-step demonstration of the client address migration feature in MQTT over QUIC. We will assume that you have a basic understanding of MQTT and some familiarity with the concept of QUIC.
Let's dive into the demo.
Set up the MQTT over QUIC environment.
Begin by provisioning the test cluster using the provided AWS CDK script available at GitHub - emqx/cdk-emqx-cluster.
Follow the instructions in the repository to deploy the cluster in your AWS environment.
The cluster setup includes an EMQX MQTT broker, two load generators, and monitoring services.
The EMQX MQTT broker version used in this demo is open-source 5.0.26.
The load generators are configured to support the QUIC protocol using the emqtt-bench tool.
CDK_EMQX_CLUSTERNAME=william cdk deploy CdkEmqxClusterStack -c retain_efs=FALSE -c emqx_n=1 -c lg_n=2 -c emqx_ins_type="m5.xlarge" -c loadgen_ins_type="m5.xlarge" --parameters sshkey=qzhuyan -c emqx_src="wget https://github.com/emqx/emqx/releases/download/v5.0.26/emqx-5.0.26-ubuntu20.04-amd64.deb"
Outputs: CdkEmqxClusterStack.BastionBastionHostId8F8CEB82 = i-013c898310b5e2f41 CdkEmqxClusterStack.ClusterName = william CdkEmqxClusterStack.EFSID = fs-006b96ed41efd7efd CdkEmqxClusterStack.ExportsOutputRefVPCEMQXwilliamA0A7F0C5ED461C91 = vpc-0bc7e7f3261e0ac59 CdkEmqxClusterStack.ExportsOutputRefVPCEMQXwilliamPrivateSubnet1SubnetDAC171FE82109DBA = subnet-00967d6e2a803ca98 CdkEmqxClusterStack.Hostsare = emqx-0.int.william etcd0.int.william etcd1.int.william etcd2.int.william loadgen-0.int.william loadgen-1.int.william CdkEmqxClusterStack.Loadbalancer = emqx-nlb-william-dd5d78ce97949e12.elb.eu-north-1.amazonaws.com CdkEmqxClusterStack.MonitoringGrafana = lb.int.william:3000 CdkEmqxClusterStack.MonitoringPostgresPassword = william CdkEmqxClusterStack.MonitoringPrometheus = lb.int.william:9090 CdkEmqxClusterStack.SSHCommandsforAccess = ssh -A -l ec2-user 16.16.202.211 -L 8888:lb.int.william:80 -L 13000:lb.int.william:3000 -L 19090:lb.int.william:9090 -L 15432:lb.int.william:5432 -L 28083:lb.int.william:8083 2>/dev/null CdkEmqxClusterStack.SSHEntrypoint = 16.16.202.211
Start the publishers.
On the host assigned to the publishers, open two separate terminals or command prompt windows.
In one terminal, start the publisher using TCP transport by running the appropriate command.
This publisher will publish messages to the topic '/over/tcp', binding to the local address 192.168.0.200
./emqtt_bench pub -h emqx-0.int.william -t '/over/tcp' -c 1 --ifaddr 192.168.0.200 -q 1 --prefix PubTCP
In the other terminal, start the publisher using QUIC transport using the command.
This publisher will publish messages to the topic '/over/quic', binding to the local address 192.168.0.200
./emqtt_bench pub -h emqx-0.int.william -t '/over/quic' --quic -p 14567 -c 1 --ifadd r 192.168.0.200 -q 1 --prefix PubQUIC
Start the subscribers.
On the host assigned to the subscribers, open two separate terminals or command prompt windows.
In one terminal, start the subscriber for TCP by running the necessary script or command.
This subscriber will subscribe to the topic '/over/tcp', QoS 1
./emqtt_bench sub -h emqx-0.int.william -t '/over/tcp' -c 1 -q 1
In the other terminal, start the subscriber for QUIC using the appropriate script or command.
This subscriber will subscribe to the topic '/over/quic', QoS 1
./emqtt_bench sub -h emqx-0.int.william -t '/over/quic -c 1 -q 1
emqtt_bench prints the receiving message rate on the console.
Monitor message flow.
Observe the terminals for the subscribers and ensure that they start receiving messages from the respective topics.
Monitor the console output to view the receiving message rates for '/over/tcp' and '/over/quic'.
Monitor the EMQX console that the peer client src IP address is from 192.168.0.200.
sudo tcpdump -i ens5 -n net 192.168.0.0/24
Trigger the NAT rebinding.
Simulate the client source address change by triggering a NAT rebinding event that changes client src address from 192.168.0.200 to 192.168.0.203 for both TCP and UDP (QUIC) protocol.
sudo iptables -t nat -I POSTROUTING -s 192.168.0.200 -j SNAT --to-source 192.168.0.203 sudo conntrack -F
Observe the behavior of the MQTT over QUIC connections as the address migration event occurs.
Validate the address migration.
Monitor the terminals for the subscribers and check that they continue to receive messages after the address migration.
Verify that the receiving message rates for '/over/quic' topics are maintained without interruption.
Monitor the EMQX console that the peer client src IP address is from 192.168.0.203.
Revert back to the old src address. This simulates the client switch back to the old network and get back the old source address.
# EMQX sudo iptables -F -t nat
Tear down the test environment.
Execute the following command in your terminal to tear down the test cluster:
CDK_EMQX_CLUSTERNAME=william cdk destroy CdkEmqxClusterStack -c retain_efs=FALSE -cemqx_n=1 -c lg_n=2 -c emqx_ins_type="m5.xlarge" -c loadgen_ins_type="m5.xlarge" --parameters sshkey=qzhuyan -c emqx_src="wget https://github.com/emqx/emqx/releases/download/v5.0.26/emqx-5.0.26-ubuntu20.04-amd64.deb"
By following these detailed steps in the demo, you can conduct a comprehensive demonstration of the client address migration feature in MQTT over QUIC. The test cluster provision ensures an environment suitable for testing the behavior of MQTT connections during address changes. Starting the publishers and subscribers allows you to observe the message flow and receiving message rates. Finally, triggering the NAT rebinding event simulates the client source address change, enabling you to validate the address/connection migration capabilities of MQTT over QUIC.
Conclusion
In this blog post, we explored the client address migration feature in MQTT over QUIC and its benefits in handling address changes during active connections. We discussed the challenges faced by MQTT over TCP when encountering address migration, including connection drops and reestablishment, as well as the additional load on MQTT brokers. We also acknowledged the complexity of simulating address changes in testing environments.
MQTT over QUIC emerged as a powerful solution to address these challenges. By leveraging the capabilities of the QUIC protocol, MQTT over QUIC offers seamless address migration resilience, reduced load on MQTT brokers, and simplified development and testing processes. This protocol proves particularly valuable in modern mobile networks, where client source address changes are prevalent.
Through the step-by-step demonstration, we showcased the effectiveness of MQTT over QUIC in handling client address migration. By adopting MQTT over QUIC, developers and organizations can enhance the reliability, scalability, and overall performance of their MQTT-based systems.
As IoT applications continue to evolve in dynamic network environments, MQTT over QUIC proves to be a valuable protocol choice with its ability to handle address migration seamlessly. With the effort of EMQX as the first MQTT broker that supports MQTT over QUIC, we can expect further advancements in addressing network related challenges and enabling seamless communication in the ever-expanding world of IoT.