The number of devices connected to the Internet of Things (IoT) surpassed the number of smartphones and personal computers some time ago, and will overtake the number of people on the planet this year.  Gartner estimates that over 20 billion devices will be connected to IoT by 2020, growing at about 30 percent annually.

Most IoT projects involve only a few hundred or thousand connected devices, but even a seemingly simple application can require hundreds of thousands of connections between devices and generate millions of information updates a second depending on the frequency of updates from those devices.

An IoT architecture with many devices, intermediary nodes (where aggregation and processing may occur) and back-end systems like applications and analytics engines was once an extreme example of distributed computing, but is the new norm.


With so many nodes as part of a single application, you can be sure that something will always be wrong somewhere – devices will need repair, the aggregating nodes will break or reach capacity, or some datacenter asset will be offline.  At any given time, 99% plus of the entire system will behave as expected, but the problem that needs attention will always be different and fluid.  And it’s critical that your IoT application run seamlessly whether all the components of the system are working perfectly or not.

Decoupling Equals Messaging

iot-without-messagingThe well-accepted way to deal with this challenge is to decouple the nodes and design all communication and data exchanges to be asynchronous.  When everything is working correctly, data flows as anticipated and when something goes wrong, most data still flows as anticipated.  In contrast, if an application tries to do this by connecting applications with point-to-point links, a single node’s problem often has a cascading effect that can shut the whole application down.  The only alternative a developer has with this approach is to write reams of code that anticipate and work around every possible failure scenario.  It gets unwieldy very quickly as illustrated here.

iot-with-messagingThat’s why software architects and developers have turned to messaging to solve distributed computing problems for decades.  Decoupling is a core tenet of computer science for distributed architectures. By decoupling endpoints, a message bus makes data exchange fully asynchronous, and can automatically handle caching, buffering and routing challenges when nodes experience failures or slowdowns.  That’s why a well-designed message bus can automatically resolve most of the problems that would cause large-scale outages otherwise.


There are many more details related to IoT and messaging like message exchange patterns, protocols and APIs  like MQTT, REST, JMS, AMQP and more. Check out my blog post “Understanding IoT Protocols – Matching your Requirements to the Right Option” to learn more which might be right for your applications.

Solace logo

Solace helps large enterprises become modern and real-time by giving them everything they need to make their business operations and customer interactions event-driven. With PubSub+, the market’s first and only event management platform, the company provides a comprehensive way to create, document, discover and stream events from where they are produced to where they need to be consumed – securely, reliably, quickly, and guaranteed.

Behind Solace technology is the world’s leading group of data movement experts, with nearly 20 years of experience helping global enterprises solve some of the most demanding challenges in a variety of industries – from capital markets, retail, and gaming to space, aviation, and automotive.

Established enterprises such as SAP, Barclays and the Royal Bank of Canada, multinational automobile manufacturers such as Renault and Groupe PSA, and industry disruptors such as Jio use Solace’s advanced event broker technologies to modernize legacy applications, deploy modern microservices, and build an event mesh to support their hybrid cloud, multi-cloud and IoT architectures.