SlideShare a Scribd company logo
0MQ 
SOCKETS ON STEROIDS!!!
AGENDA 
Overview 
Message Oriented 
Disconnected 
Async 
Bindings / Platforms 
Patterns 
Request / Reply 
Async Req /Rep 
Pub / Sub 
Pipeline 
Pairing
WTF IS 0MQ??
WTF IS 0MQ?
WTF IS 0MQ? 
"ZEROMQ IS WHAT BSD SOCKETS MAY 
LOOK LIKE IF THEY WERE DESIGN 
TODAY"
WTF IS 0MQ? 
ZEROMQ IS A MESSAGE ORIENTED 
COMMUNICATION LIBRARY!!
OVERVIEW 
C++ Implementation 
In-memory queue 
Atomic Messages 
API for ZMTP Protocol 
Zero copy 
Multipart messages support
OVERVIEW 
Disconnected Sockets 
Background I/O to send/receive 
Queues at sender and receiver 
Automatic Reconnect 
Message size limited by memory size
OVERVIEW 
Async 
Polling over BSD sockets 
Batch messages over the wire 
Fast 
Over 8M msg/s
OVERVIEW 
Protocol Support with i nterchangeability 
inproc: in memory 
ipc: inter process 
tcp 
pgm/epgm: multicast
OVERVIEW 
Platform support 
Linux 
Windows 
iOS 
Android 
Raspabery Pi
OVERVIEW 
+30 Bindings 
Ruby 
Node-js 
.NET 
Java 
C++ 
Cobol 
Go 
...
OVERVIEW 
What you will not have out of the box 
Message Persistency (Pirate pattern) 
Data serialisation: use what ever you desire 
msgpack 
json 
protobuff 
... 
Data compression 
Message encryption 
Security Protocol 
Include in the next version of ZMTP
API 
Socket Types 
REQ: Request 
REP: Reply 
DEALER: Async Request/Reply 
ROUTER: Routing 
PUB: Publisher 
SUB: Subscriber 
PUSH: Pipeline writer 
PULL: Pipeline consumer
API - NODE JS 
$ npm install zmq 
$ node 
var zmq = require( 'zmq'); 
var socket = zmq.socket( 'rep'); 
socket.bind( 'inproc://queue'); // server 
socket.connect(<span style= "font-family: monospace; font-size: socket. on('message', function(frame1, frame2){}); 
socket. on('error',function(error){}); 
socket.send( 'something'); 
socket.send([ 'multipart1', 'multipart2']);<br>socket.close();
PATTERNS 
REQUEST / REPLY 
ASYNC REQUEST / REPLY 
PUBLISHER / SUBSCRIBERS 
PIPELINE 
PAIR
REQUEST / REPLY
DOJO - REQUEST /REPLY
ASYNC REQUEST / REPLY
DOJO - REQUEST /REPLY ASYNC
PUB / SUB
DOJO - PUB /SUB
PIPELINE
PAIR
MAJORDOMO PATTERN 
http://rfc.zeromq.org/spec:7
DOJO - MAJORDOMO
LINKS 
0MQ Guide 
http://zguide.zeromq.org/page:all 
0MQ Guide Examples 
git clone --depth=1 git://github.com/imatix/zguide.git
ANY DOUBTS
PEDRO JANUÁRIO 
THANKS!!! 
http://shared-mind.tumblr.com 
https://www.linkedin.com/in/pjanuario 
https://twitter.com/prnjanuario 
https://github.com/pjanuario
COMING NEXT 
ZMQ 
SOA SERVICE SUITE 
http://pjanuario.github.io/zmq-service-suite-specs/

More Related Content

KEY
Europycon2011: Implementing distributed application using ZeroMQ
ODP
Overview of ZeroMQ
KEY
PDF
Zmq in context of openstack
ODP
FOSDEM 2011 - 0MQ
PPTX
zeromq
PDF
Lindsay distributed geventzmq
Europycon2011: Implementing distributed application using ZeroMQ
Overview of ZeroMQ
Zmq in context of openstack
FOSDEM 2011 - 0MQ
zeromq
Lindsay distributed geventzmq

What's hot (20)

PDF
Introduction to ZeroMQ - eSpace TechTalk
PPTX
ZeroMQ: Super Sockets - by J2 Labs
PDF
ZeroMQ with NodeJS
PPTX
Build reliable, traceable, distributed systems with ZeroMQ
ODP
Event Driven with LibUV and ZeroMQ
PDF
Zeromq anatomy & jeromq
KEY
Distributed app development with nodejs and zeromq
PPT
Leveraging zeromq for node.js
PDF
Python Ireland 2012 - Message brokers and Python by Fernando Ciciliati
PDF
memcached Binary Protocol in a Nutshell
ODP
Scala.io 2013 - Scala and ZeroMQ: Events beyond the JVM
ODP
Enduro/X Middleware
ODP
Rabbit mq, amqp and php
PPTX
MQTT enabling the smallest things
PPTX
Techniques to Improve Cache Speed
PDF
MOVED: The challenge of SVE in QEMU - SFO17-103
ODP
sshuttle VPN (2011-04)
PDF
The art of concurrent programming
PPTX
Information and data security block cipher operation
PPTX
Rabbit MQ
Introduction to ZeroMQ - eSpace TechTalk
ZeroMQ: Super Sockets - by J2 Labs
ZeroMQ with NodeJS
Build reliable, traceable, distributed systems with ZeroMQ
Event Driven with LibUV and ZeroMQ
Zeromq anatomy & jeromq
Distributed app development with nodejs and zeromq
Leveraging zeromq for node.js
Python Ireland 2012 - Message brokers and Python by Fernando Ciciliati
memcached Binary Protocol in a Nutshell
Scala.io 2013 - Scala and ZeroMQ: Events beyond the JVM
Enduro/X Middleware
Rabbit mq, amqp and php
MQTT enabling the smallest things
Techniques to Improve Cache Speed
MOVED: The challenge of SVE in QEMU - SFO17-103
sshuttle VPN (2011-04)
The art of concurrent programming
Information and data security block cipher operation
Rabbit MQ
Ad

Similar to ZeroMQ - Sockets on steroids! (20)

PPTX
Socket programming with php
PPT
Transport layer of computer networking 2
PDF
Messaging on the cloud with xPAAS
PPTX
Js remote conf
PPT
Exploiting Network Protocols To Exhaust Bandwidth Links 2008 Final
PDF
NUSE (Network Stack in Userspace) at #osio
PDF
CODEONTHEBEACH_Streaming Applications with Apache Pulsar
PPTX
Mom those things v1
PDF
OSS EU: Deep Dive into Building Streaming Applications with Apache Pulsar
PDF
Apache Pulsar with MQTT for Edge Computing - Pulsar Summit Asia 2021
DOCX
Certified Ethical Hacker quick test prep cheat sheet
PPTX
The Potential Impact of Software Defined Networking SDN on Security
PPTX
XMPP-IoT Protocol designed mainly to send mesages
PDF
OSMC 2014: MQTT for monitoring (and for the lo t) | Jan-Piet Mens
PDF
Of the variedtypes of IPC, sockets arout and awaythe foremostcommon..pdf
PDF
Down the RabbitMQ Hole
PPTX
Attacks and their mitigations
PPTX
PLNOG 13: P. Kupisiewicz, O. Pelerin: Make IOS-XE Troubleshooting Easy – Pack...
ODP
import rdma: zero-copy networking with RDMA and Python
Socket programming with php
Transport layer of computer networking 2
Messaging on the cloud with xPAAS
Js remote conf
Exploiting Network Protocols To Exhaust Bandwidth Links 2008 Final
NUSE (Network Stack in Userspace) at #osio
CODEONTHEBEACH_Streaming Applications with Apache Pulsar
Mom those things v1
OSS EU: Deep Dive into Building Streaming Applications with Apache Pulsar
Apache Pulsar with MQTT for Edge Computing - Pulsar Summit Asia 2021
Certified Ethical Hacker quick test prep cheat sheet
The Potential Impact of Software Defined Networking SDN on Security
XMPP-IoT Protocol designed mainly to send mesages
OSMC 2014: MQTT for monitoring (and for the lo t) | Jan-Piet Mens
Of the variedtypes of IPC, sockets arout and awaythe foremostcommon..pdf
Down the RabbitMQ Hole
Attacks and their mitigations
PLNOG 13: P. Kupisiewicz, O. Pelerin: Make IOS-XE Troubleshooting Easy – Pack...
import rdma: zero-copy networking with RDMA and Python
Ad

Recently uploaded (20)

PPTX
ISO 45001 Occupational Health and Safety Management System
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PDF
Nekopoi APK 2025 free lastest update
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PDF
Softaken Excel to vCard Converter Software.pdf
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PPTX
Operating system designcfffgfgggggggvggggggggg
PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PDF
System and Network Administraation Chapter 3
PPTX
Transform Your Business with a Software ERP System
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PPTX
Online Work Permit System for Fast Permit Processing
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
PPTX
L1 - Introduction to python Backend.pptx
ISO 45001 Occupational Health and Safety Management System
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PTS Company Brochure 2025 (1).pdf.......
Navsoft: AI-Powered Business Solutions & Custom Software Development
Nekopoi APK 2025 free lastest update
Design an Analysis of Algorithms II-SECS-1021-03
Softaken Excel to vCard Converter Software.pdf
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Operating system designcfffgfgggggggvggggggggg
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
System and Network Administraation Chapter 3
Transform Your Business with a Software ERP System
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
2025 Textile ERP Trends: SAP, Odoo & Oracle
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Upgrade and Innovation Strategies for SAP ERP Customers
Online Work Permit System for Fast Permit Processing
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
L1 - Introduction to python Backend.pptx

ZeroMQ - Sockets on steroids!