Categories: Article

A Collection of 20+ MQTT Broker Performance Benchmarks (2020–2023)

(Featured image credit)

What are the latencies and throughput of Mosquitto, VerneMQ, EMQX, NanoMQ, HiveMQ, RabbitMQ, BifroMQ, ActiveMQ, etc.?

Performance matters

For the past two years, the number of connected IoT devices has been growing by over 2 billion annually, according to IoT Analytics. At the same time, performance of MQTT brokers directly affects the number of devices that IoT systems can handle while maintaining reasonable speed and reliability. With minimal latencies, brokers need to handle high throughput without dropping messages or using too much resources.

To help you get an idea of how different MQTT products perform in various scenarios, we’ve compiled a list of benchmarks published by various researchers and vendors between 2020 and 2023. We also brought together papers that evaluate public sandboxes or compare MQTT brokers to other alternatives, as well as found a few articles on how to conduct your own benchmarks. Some of the papers are truly independent, while others present the results from one of the vendors. Still, all the reports shed some light on how the tools differ and may behave under various conditions.

Third-party evaluation of MQTT brokers

Mosquitto vs. HiveMQ vs. VerneMQ vs. EMQX vs. MQTTRoute vs. ActiveMQ

In September 2021, a group of researchers from the University of Szeged (Hungary) and Wind River (a subsidiary of Aptiv) benchmarked the performance of six MQTT brokers. The tests were done from a machine-to-machine (M2M) communication perspective, since Aptiv/Wind River’s business is focused on embedded systems. Stress load was evaluated in both local and distributed/multi-core (cloud) environments—revealing latencies and throughput at 100% CPU use and when resource usage is unrestricted.

For the purposes of the comparison, the team developed the MQTT Blaster benchmarking tool based on Eclipse Paho. “The findings of this research highlight the significance of the relationship between MQTT broker system design and its performance under stress testing,” the authors noted in their analysis.

The average latencies of MQTT brokers in a cloud environment (image credit)

EMQX vs. HiveMQ vs. VerneMQ

“A Comparison of MQTT Brokers for Distributed IoT Edge Computing” is, indeed, a fundamental MQTT broker comparison (see the document). Delivered by ABB in 2020, it aims to evaluate the messaging tools from a point of view of industrial engineer/software architect. Focusing on distributed MQTT brokers suitable fot the edge workloads, the authors used a scientific approach to calculate throughput, scalability, resilience, etc. The results were obtained by utilizing MZBench, vmq_mzbench, and MQTT Explorer.

Lost messages and CPU utilization (TLS-related) for EMQX and VerneMQ (image credit)

Vendor-owned benchmarks

EMQX/NanoMQ vs. VerneMQ vs. Mosquitto

In April 2023, MQTT vendor EMQX conducted a series of performance benchmarks. The team compared EMQX’s distributed broker against its own lightweight MQTT tool for IoT edge workloads—NanoMQ—as well as explored VerneMQ and Mosquitto. The benchmarks were implemented with EMQX’s XMeter (based on JMeter) and—in addition to latencies and throughput—also revealed CPU and memory usage, message rate limits, etc. The scenarios included both small-scale performance evaluation and enterprise-level tests. The benchmarking was done with a 16-bytes payload and included point-to-point, fan-out, and fan-in scenarios at QoS 1 and publish:subscribe ratios of 50,000:50,000, 5:250,000, and 50,000:5 respectively.

Here’s a consolidated report, as well as more detailed separate comparisons of EMQX to NanoMQ, VerneMQ, and Mosquitto. One more benchmark evaluating NanoMQ vs. Mosquitto can be found here. This GitHub repository describes the comparison’s methodology and scenarios in detail.

EMQX’s benchmark results for the point-to-point scenario (image credit)

FlashMQ vs. VerneMQ vs. EMQX vs. NanoMQ (vs. HiveMQ vs. Mosquitto)

In 2021–2022, MQTT startup FlashMQ conducted several benchmarks—some of them were recorded as live demos. For instance, this video demonstrates the maximum number of clients and messages achieved for VerneMQ, EMQX, NanoMQ, and FlashMQ. In a separate recording, the team shows how FlashMQ reaches 4,000,000 connections per second, competing with HiveMQ, Mosquitto, and VerneMQ. Another benchmark from this vendor aimed to evaluate CPU use against performance (throughput) of VerneMQ, EMQX, and FlashMQ.

Throughput results for VerneMQ, EMQX, and FlashMQ (image credit)

Sandboxes/public MQTT brokers

Mosquitto vs. HiveMQ vs. MQTTHQ vs. EMQX vs. flespi

An insightful benchmark was conducted in October 2022 by Dr. Gough Lui, a postdoctoral researcher at Western Sydney University. The goal was to explore public and free MQTT services that can be used for very small projects or proof-of-concepts. The test were implemented by using the paho-mqtt library (the code is provided in the report). Quite expected, the author experienced disconnections, spikes in latencies, and dropped messages from time to time.

Dr. Gough Lui

“The performance of the MQTT servers seem to be dominated mostly by network latency…While public and free MQTT servers can be useful for testing and hobby projects, it is important to remember that these services may not be around forever and may go down from time to time. As a result, any serious application should consider hosting their own server.”

Latency results for public and free MQTT broker services (image credit)

EMQX vs. HiveMQ vs. Mosquitto vs. Eclipse IoT’s MQTT

Earlier report from EMQX—released in November 2021—also evaluated a number of free public brokers. It looked into accessibility (using MQTTX), international network delays (the time required for DNS resolution and to establish a TCP connection), average message transmission delays (from Pub to Sub), etc. To evaluate Pub/Sub rates, the team utilized EMQX’s lightweight eMQTT-Bench tool written in Erlang. Here’s the code for message transmission delay tests.

This benchmark discovered unstable network delays, connection failures, and a small amount of packet loss when testing one of the services, too. The authors also suspected some servers of having a scheduled restart mechanism.

Latencies for public sandboxes of EMQX, HiveMQ, Mosquitto, and Eclipse IoT’s MQTT (image credit)

Self-evaluation

HiveMQ

In February 2023, HiveMQ delivered a performance benchmark of its platform to demonstrate the maximum number of connections the tool can support. The test was run on AWS EC2 and a HiveMQ Swarm instance, and the ramp up to 200 million connections took 37 minutes.

The number of connected HiveMQ clients over time (image credit)

NanoMQ

EMQX shares additional performance data for NanoMQ in the product’s documentation. The team ran tests on three different server configurations, using EMQX’s XMeter. Scenarios included 1:1 send:receive and broadcast message testing.

Server load results for NanoMQ (image credit)

RabbitMQ

In March 2023, RabbitMQ released a performance benchmark demonstrating the improvements of its latest v3.12 compared to v3.11. The team evaluated memory usage when connecting 1 million MQTT clients and during the point-to-point scenario with the 100,000:100,000 ratio, as well as measured latencies and throughput.

Latency and throughput results for RabbitMQ (image credit)

BifroMQ

BifroMQ is a brand-new MQTT broker open-sourced by Baidu in July 2023. Its documentation contains a comprehensive performance evaluation report, which was conducted—according to the screenshots—in May and June 2023. While the resulting table says the tool can handle 200,000+ messages per second for high-frequency scenarios, the main product page also notes that the tool supports up to 180 million connected clients.

The performance of BifroMQ according to the product’s documentation (image credit)

Comparing alternatives to MQTT

Mosquitto vs. Zenoh vs. Kafka vs. DDS

In March 2023, researchers from the National Taiwan University tested four popular messaging solutions (see the blog post and the paper). The experiment encompassed two scenarios: one was run on a single machine, and the other used multiple servers connected via Ethernet. For the throughput benchmark, payload sizes varied from 8 bytes to 512 MiB, while latency was tested with the payload fixed at 64 bytes.

Throughput results for the single machine scenario (image credit)

GitHub repository

RabbitMQ vs. Apache Pulsar vs. NATS JetStream

Streamnative, a company behind a messaging and streaming platform, conducted another benchmark in Q1 2023. The report encompasses four scenarios—node failure, topic counts, subscription counts, and backlog draining—with 1 KB messages.

Comparison of Apache Pulsar, RabbitMQ, and NATS JetStream (image credit)

GitHub repository

LavinMQ vs. RabbitMQ

In April 2023, 84codes—the team behind LavinMQ, CloudAMQP, and CloudMQTT—delivered a couple of own AMQP benchmarks. Evaluating RabbitMQ and LavinMQ, the performance was measured with different message sizes (16 and 1,024 bytes), emulating 3 producers and 5 consumers. The tests were done with the lavinmqperf tool, utilizing RabbitMQ’s PerfTest in some of the scenarios.

Throughput and latency of LavinMQ (left, source) vs. RabbitMQ (right, source)

ActiveMQ vs. Kafka vs. Zenoh vs. Pulsar

Researchers from the University of Antwerp ran this comparison in September 2022. The benchmark used a fixed RSU, which communicated with a mobile OBU over 4G with a payload size of 256 bytes.

Latency and resource utilization results (image credit)

ActiveMQ Artemis vs. RabbitMQ vs. Redis vs. Apache Kafka

In June 2023, computer science researchers at Baylor University measured the throughput and latency of these four dissimilar yet popular products. The study utilized the OpenMessaging Benchmark Framework.

Throughput and median latency (image credit)

RabbitMQ vs. Apache Kafka vs. Apache Pulsar

Confluent—a company behind a cloud-native data streaming platform—conducted this benchmark in August 2020. The tests used three Amazon EC2 i3en.2xlarge instances for the producer, broker, and consumer.

Throughput and latency results for RabbitMQ, Pulsar, and Kafka (image credit)

GitHub repository

Mosquitto vs. RabbitMQ vs. FastRTPS vs. GlassFish

Researchers at St. Petersburg Electrotechnical University published another paper in August 2022. The tests ran on a single server, using message sizes of 50 and 60,000 bytes.

Latency test results for GlassFish and Mosquitto (image credit)

How to benchmark message brokers?

If you want to conduct your own MQTT broker comparison, there are numerous articles that provide additional guidance on specific tools and approaches. E.g., EMQX explains how they benchmarked NanoMQ using their Open MQTT Benchmark Suite. In addition, the vendor has a tutorial on benchmarking their distributed broker with eMQTT-Bench.

In this paper, a group of researchers used Gatling to test the performance of MQTT brokers. Gatling goes into more detail about using their tool for MQTT performance testing in a recent tutorial.

An architecture for testing distributed MQTT brokers (image credit)

This study provides a detailed guide on using MQTTBrokerBench to evaluate various MQTT brokers. Another research paper demonstrates how to test MQTT brokers with MQTTLoader. The post from JoinBase shows how to measure MQTT broker performance with the Open IoT Database Benchmark Suite (OIDBS). An article by VerneMQ covers the basics of load testing with Machinezone’s MZBench framework. Another blog post from BlazeMeter explains how to set up Apache JMeter for testing MQTT brokers.

Founder of VOLSOFT Volkan Alkılıç showcased how to benchmark MQTT brokers in his blog post. The article explains how to do this with ThingsOn MQTT Bench—a performance testing tool that Volkan developed for the purpose.

Volkan Alkılıç

“As an IoT and messaging systems developer, I struggled to find a benchmark tool that met my needs when testing the performance of MQTT brokers for my IIoT Platform. Most tools I found were either too complicated or too basic, and lacked the level of customization and control I desired. This motivated me to create my own benchmark tool that is simple, lightweight, and flexible, allowing for easy adaptation to various scenarios and requirements.”

 
—Volkan Alkılıç, VOLSOFT

Benchmarks indicate that the performance of MQTT brokers depends heavily on the scenario and configuration. Still, technology benchmarking can reveal unexpected behavior—including unstable latency, dropped messages, and limits on the number of connections. In addition to other details about latency and throughput, these insights are also vital to understanding how the evaluated technology fits the specific requirements of your project.

If you know any other MQTT performance benchmarks we missed—feel free to add them in the comments.

Further reading


This article is written by Alex Khizhniak and Yaroslav Goortovoi.
Alex Khizhniak

Alex Khizhniak is Director of Technical Content Strategy at Altoros and a cofounder of Belarus Java User Group. Managing distributed teams since 2004, he has gained experience as a journalist, an editor-in-chief, a technical writer, a technology evangelist, a project manager, and a product owner. Alex is obsessed with AI/ML, data science, data integration, ETL/DWH, data quality, databases (SQL/NoSQL), big data, IoT, and BI. The articles and industry reports he created or helped to publish reached out to 3,000,000+ tech-savvy readers. Some of the pieces were covered on TechRepublic, ebizQ, NetworkWorld, CIO.com, etc. Find him on Twitter at @alxkh.

Recent Posts

A List of 30+ Apache Kafka Performance Benchmarks (2020–2023)

Explore evaluations of Kafka’s performance on various cloud platforms, as well as benchmarks against other…

1 year ago

Rule-Based Stream Data Processing at the Edge with eKuiper

Governed by LF and designed to shift data analytics closer to devices, this lightweight IoT…

1 year ago

Industrial IoT in Manufacturing: Major Pains for a CTO to Address

Aiming for operational improvements, manufacturers are struggling with system complexities. Is there a way out?

1 year ago

LF’s Project Alvarium: Ensuring Trusted IoT Data at the Edge with DLT

Supported by Dell, IOTA, Intel, etc., this open-source project assigns trust scores to sensor data,…

2 years ago

Alternatives to Google Cloud IoT Core—Where to Migrate?

Google will sunset its IoT Core on August 16, 2023. Some of the edge devices…

2 years ago

46% of Medical IoT Devices Have a Vulnerability, a New Study Reveals

For 53% of institutions, breaches in connected systems affect patients—e.g., lead to delayed surgeries or…

2 years ago