SlideShare a Scribd company logo
SCALING MQTT WITH
KAFKA
Tim Kellogg
April 7, 2014
@kellogh
•  MQTT broker
•  Protocol onboarding
•  Cloud environment (we’re a startup)
Scaling MQTT With Apache Kafka
•  Standard
•  Lightweight
o  >= 2 byte overhead per message
•  Easy to parse
o  Length prefixed strings
•  Requires very little resources on client side
o  Broker keeps track of state
•  Reliable
o  QoS 1 & 2
o  Last Will & Testament messages
•  Secure
o  Username + Password
o  Tunnel over TLS
Publish / Subscribe
Pub
Pub
Pub
Broker
Sub
Topic/A
Topic/B
Topic/C
Topic/B
SubTopic/C
SubTopic/A
Topics
•  foo/bar/baz
•  com.example/device/17/thermo
•  Patterns
•  com.example/device/+/thermo
•  com.example/device/#
Scaling Goals
•  More than 2 Million
connected publishers
•  More than 65,000
msg/s
•  Single subscriber
Scaling Goals
•  Amazon’s EC2
•  Horizontal scaling
o  Reduce cost
o  Plan for the future
o  Less impact from
downtime
Problems with Scaling MQTT
Load Balancing
•  Which broker to connect to?
o  DNS load balancing
•  HAProxy
•  QoS 1-2 messages stored in
Cassandra
o  Consistent hash ring
Single Subscriber
Pub
Pub
Pub
Broker
Sub
Topic/A
Topic/B
Topic/C
Topic/#
Single Subscriber
Pub
Pub
Pub
Broker
Sub
Topic/A
Topic/B
Topic/C
Topic/#
Broker
Broker
LoadBalancing
Single Subscriber
Pub
Pub
Pub
Broker
Sub
Topic/A
Topic/B
Topic/C
Topic/#
Broker
Broker
LoadBalancing
LoadBalancing
Single Subscriber
Broker
Subscriber
Topic/#
Broker
Broker
Using HTTP
POST From The Broker
Pub
Pub
Pub
Broker
Topic/A
Topic/B
Topic/C Broker
Broker HTTP POST
LoadBalancing
Server
HTTP POST Server
HTTP POST Server
LoadBalancing
Benefits
•  Easy to load balance
•  Well known & well
supported
Drawbacks
•  HTTP is heavy
•  Headers
•  Creating & destroying
TCP connections
•  Subscriber servers must
be available
•  Retry logic to guarantee
delivery
Apache Kafka
• 
•  Distributed log
aggregation framework
•  Server to server
•  “Smart” clients
•  Apache ZooKeeper
•  Append-only files per topic
o  Client keeps track of what messages it’s processed
•  No topic wildcards
•  Key is used for out of band data
•  device/42/thermo è topic: device-thermo key: 42
Subscriber Group
Pub
Pub
Pub
Broker
Subscriber Group
Pub
Pub
Pub
Broker
Broker
Broker
LoadBalancing
Kafka
Results
•  Linear scaling for fire hose subscriber
•  At least 2 million clients
•  At least 65,000 msg/s
Wish List
•  Security
•  Configuration
Open Source IoT
The Book: Mastering The Internet of Things
Questions?
@kellogh

More Related Content

PDF
PPTX
Basic Principles Of Graphics and Layout
PPTX
Collaborative ICT Development - Empowerment Technologies
PPTX
Natures and Purpose of Online Platforms and Applications
PPTX
10. Earth's Interior Heat Notes
PPTX
E-Tech L3 Advanced Word Processing Skills.pptx
PPT
The geological time scale
PPTX
Empowerment Technology by: Maria Elisa Pal and Rodel Reyes
Basic Principles Of Graphics and Layout
Collaborative ICT Development - Empowerment Technologies
Natures and Purpose of Online Platforms and Applications
10. Earth's Interior Heat Notes
E-Tech L3 Advanced Word Processing Skills.pptx
The geological time scale
Empowerment Technology by: Maria Elisa Pal and Rodel Reyes

What's hot (20)

PPTX
Making Powerpoint Presentation
PPTX
Basic Image Manipulation using Offline or Open-source Application.
PDF
Personal development
PDF
Google meet guide file
PPTX
Online Platform :Empowerment of technologies ICT
PDF
Earth and Life Science - The Solar System
PPTX
Basic principles of graphics and layout
PPTX
E-Tech L6 Imaging and Design for Online Environment.pptx
PPTX
Creating mail merge
PDF
Ejercicio práctico power point no. 1
PPTX
Web 1.0
PPTX
PPT
Microsoft Powerpoint
PPT
Earth Science Astronomy - The big bang theory
PDF
Show Don't Tell - Creating Visually Useful Infographics For Your Audience
PPTX
Science Powerpoint.pptx
PDF
Basic human values hebrew university
PPTX
Week 4-Rocks.pptx
PPT
Powerpoint presentation
Making Powerpoint Presentation
Basic Image Manipulation using Offline or Open-source Application.
Personal development
Google meet guide file
Online Platform :Empowerment of technologies ICT
Earth and Life Science - The Solar System
Basic principles of graphics and layout
E-Tech L6 Imaging and Design for Online Environment.pptx
Creating mail merge
Ejercicio práctico power point no. 1
Web 1.0
Microsoft Powerpoint
Earth Science Astronomy - The big bang theory
Show Don't Tell - Creating Visually Useful Infographics For Your Audience
Science Powerpoint.pptx
Basic human values hebrew university
Week 4-Rocks.pptx
Powerpoint presentation
Ad

Viewers also liked (20)

PPTX
Distributed messaging with Apache Kafka
PDF
Why Data, Code and Mobile converge in the Open Cloud
PDF
JAX 2014 - M2M for Java Developers with MQTT
PDF
How do Things talk? IoT Application Protocols 101
PDF
Building the Internet of Things with Eclipse IoT - IoTBE meetup
PDF
M2M, IOT, Device Managment: COAP/LWM2M to rule them all?
PDF
On Digital Transformation - 10 Observations
PDF
The Internet of Things: Are Organizations Ready For A Multi-Trillion Dollar P...
PPTX
Processing IoT Data with Apache Kafka
PDF
Low Latency Mobile Messaging using MQTT
PPTX
Designing and Implementing your IOT Solutions with Open Source
PDF
Introducing MQTT
PDF
MQTT - A practical protocol for the Internet of Things
PDF
MQTT - MQ Telemetry Transport for Message Queueing
PDF
Introduction MQTT in English
PPTX
Click-Through Example for Flink’s KafkaConsumer Checkpointing
PPTX
Apache Kafka 0.8 basic training - Verisign
PDF
Streaming Processing with a Distributed Commit Log
PDF
MQTT with Java - a protocol for IoT and M2M communication
ODP
Intoduction to Android Development
Distributed messaging with Apache Kafka
Why Data, Code and Mobile converge in the Open Cloud
JAX 2014 - M2M for Java Developers with MQTT
How do Things talk? IoT Application Protocols 101
Building the Internet of Things with Eclipse IoT - IoTBE meetup
M2M, IOT, Device Managment: COAP/LWM2M to rule them all?
On Digital Transformation - 10 Observations
The Internet of Things: Are Organizations Ready For A Multi-Trillion Dollar P...
Processing IoT Data with Apache Kafka
Low Latency Mobile Messaging using MQTT
Designing and Implementing your IOT Solutions with Open Source
Introducing MQTT
MQTT - A practical protocol for the Internet of Things
MQTT - MQ Telemetry Transport for Message Queueing
Introduction MQTT in English
Click-Through Example for Flink’s KafkaConsumer Checkpointing
Apache Kafka 0.8 basic training - Verisign
Streaming Processing with a Distributed Commit Log
MQTT with Java - a protocol for IoT and M2M communication
Intoduction to Android Development
Ad

Similar to Scaling MQTT With Apache Kafka (20)

PDF
fajfkljflafjflkflkajflajflkfkjaslfkfljjaf
PPTX
iot-application-layer-protocols-v1-200125143512.pptx
PDF
Application Layer Protocols for the IoT
PDF
MQTT – protocol for yours IoT
PPTX
IAB-5039 : MQTT: A Protocol for the Internet of Things (InterConnect 2015)
PPTX
Where next for MQTT?
PPTX
Parallel and distributed computing .pptx
PPT
UNIT2_PPT.ppt
PDF
Cloud Messaging Service: Technical Overview
PPTX
Edge to Cloud Protocol HTTP WEBSOCKET MQTT-SN MQTT.pptx
PPTX
Modern Distributed Messaging and RPC
PDF
Internet of Things (IoT) protocols COAP MQTT OSCON2014
PDF
Enterprise Messaging with RabbitMQ.pdf
PPT
Comparison of mqtt and coap protocol
PDF
Messaging for IoT
PPTX
Jms deep dive [con4864]
PDF
Capital One Delivers Risk Insights in Real Time with Stream Processing
PDF
Spark Summit EU talk by Sebastian Schroeder and Ralf Sigmund
PPTX
Building an Event Bus at Scale
PPTX
Http2 Security Perspective
fajfkljflafjflkflkajflajflkfkjaslfkfljjaf
iot-application-layer-protocols-v1-200125143512.pptx
Application Layer Protocols for the IoT
MQTT – protocol for yours IoT
IAB-5039 : MQTT: A Protocol for the Internet of Things (InterConnect 2015)
Where next for MQTT?
Parallel and distributed computing .pptx
UNIT2_PPT.ppt
Cloud Messaging Service: Technical Overview
Edge to Cloud Protocol HTTP WEBSOCKET MQTT-SN MQTT.pptx
Modern Distributed Messaging and RPC
Internet of Things (IoT) protocols COAP MQTT OSCON2014
Enterprise Messaging with RabbitMQ.pdf
Comparison of mqtt and coap protocol
Messaging for IoT
Jms deep dive [con4864]
Capital One Delivers Risk Insights in Real Time with Stream Processing
Spark Summit EU talk by Sebastian Schroeder and Ralf Sigmund
Building an Event Bus at Scale
Http2 Security Perspective

More from kellogh (9)

PDF
Biologically Inspired Internet of Things
PPTX
ThingMonk 2014: How To Improve On MQTT 3.1.1
PPTX
Why HTTP Won't Work For The Internet of Things (Dreamforce 2014)
PPTX
Functional Programming and Concurrency Patterns in Scala
PPTX
Security & Identity in AllJoyn 14.06
PPTX
Programming The Arduino Due in Rust
PPT
Why HTTP Won't Work For The Internet of Things
PPTX
Comparing CoAP vs MQTT
PDF
Internet of things, lafayette tech
Biologically Inspired Internet of Things
ThingMonk 2014: How To Improve On MQTT 3.1.1
Why HTTP Won't Work For The Internet of Things (Dreamforce 2014)
Functional Programming and Concurrency Patterns in Scala
Security & Identity in AllJoyn 14.06
Programming The Arduino Due in Rust
Why HTTP Won't Work For The Internet of Things
Comparing CoAP vs MQTT
Internet of things, lafayette tech

Recently uploaded (20)

PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
Approach and Philosophy of On baking technology
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
cuic standard and advanced reporting.pdf
PPTX
MYSQL Presentation for SQL database connectivity
PPTX
A Presentation on Artificial Intelligence
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
PDF
KodekX | Application Modernization Development
PPT
Teaching material agriculture food technology
PDF
Electronic commerce courselecture one. Pdf
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
20250228 LYD VKU AI Blended-Learning.pptx
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Review of recent advances in non-invasive hemoglobin estimation
Approach and Philosophy of On baking technology
Mobile App Security Testing_ A Comprehensive Guide.pdf
cuic standard and advanced reporting.pdf
MYSQL Presentation for SQL database connectivity
A Presentation on Artificial Intelligence
NewMind AI Weekly Chronicles - August'25 Week I
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
The Rise and Fall of 3GPP – Time for a Sabbatical?
KodekX | Application Modernization Development
Teaching material agriculture food technology
Electronic commerce courselecture one. Pdf
Chapter 3 Spatial Domain Image Processing.pdf
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy

Scaling MQTT With Apache Kafka