SlideShare a Scribd company logo
Modern Messaging for
Distributed Systems
Andrea Rabbaglietti
Modern Messaging for Distributed Systems
Agenda
● Who funk is Andrea Rabbaglietti
● Disclaimer
● Pre-requisites
○ Agentful vs. Agentless
○ Scale Up Vs. Scale Out
○ Sync Vs. Async
● IPC / Language interoperability
● Channel
○ HTTP RESTful
○ Custom
● Use Case: Facebook
● One (working & in-production) example
Who funk is Andrea Rabbaglietti
● Computer Science @ DIB alumnus
● ex-CTO Bauzaar.it
● co-founder Serverable.io
● founder JetDeploy.io
● Django Framework contributor
● Software/System Engineer
● Business coach & tutor
Context
Disclaimer
Beware!
Success..
Pre-requisites
Scaling
Stateless
Vs. Stateful
Async vs.
Sync
IPC
Scalability
Scale up
● Make a single node as fast as possible
● Increase clock speed
● Add RAM
● Make disk I/O go faster
Scale out
● Make many nodes work together
● Manage the distributed nodes
● Let the system be fault-tolerant
● Learn how to divide your problems into
independent subproblems
But is that
possible?
Stateful Vs. Stateless
class MyClass:
i = 12345
def f(self):
return 'hello world: ' + self.i
class MyClass:
def f(self):
i = 1234
return 'hello world: ' + self.i
Stateless
sessions
in-memory
cache
Stateful
Sync Vs. Async
programs have an inherent attribute:
each line executes in order
Sync
Async
Async could reveal HELL
Modern Messaging for Distributed Systems
Inter-process Communication (IPC)
● File (or memory-mapped file)
● Signal (kill)
● Socket (unix socket)
● Message queue
● Pipe
● Shared Memory
● Message passing
Legenda:
Most operating-systems
POSIX only
Language Interoperability
○ RabbitMQ
○ ZeroMQ
○ Apache Thrift
Facebook
Actor Model
Erlang VM
User (you..)
a2 a2
a3
a4
a5
a1
Java
Actor Model (2)
● No shared state
● Lightweight processes
● Asynchronous message-passing
● Mailboxes to buffer incoming messages
JetDeploy.io
Q & A
thank you so
much guys
Andrea Rabbaglietti
rabbagliettiandrea@gmail.com
GIT repo @
https://github.com/silverfix/gdgipc

More Related Content

PDF
“Practical DevOps by a small team of devs” by Ilgvars Jēcis from FinoTech  at...
PDF
Improve the deployment process step by step
PDF
Constinuous Integration
PDF
How fast can you onboard a new team member with VAGRANT ?
PPTX
That worked before
PPTX
Streamlining .net core development using Docker
ODP
OpenNTF Essentials
PDF
Fast end-to-end-tests
“Practical DevOps by a small team of devs” by Ilgvars Jēcis from FinoTech  at...
Improve the deployment process step by step
Constinuous Integration
How fast can you onboard a new team member with VAGRANT ?
That worked before
Streamlining .net core development using Docker
OpenNTF Essentials
Fast end-to-end-tests

What's hot (20)

PPTX
React web development
PPTX
BelTech 2017 - Building Quality in the Browser
PDF
Extreme Programming - to the next-level
PPTX
Develop 4 Developers
PDF
Automated Performance Testing
PDF
Introduction to Automated Testing
PDF
Stripe con 2021 UI stack
PPTX
Vagrant + SaltStack + Django - Ararat Poghosyan - DM10
PPTX
The JAMStack (Javascript, APIs, Markup).
PDF
React Webinar With CodePolitan
PPTX
Saying goodbye to localhost - developing in the cloud with Cloud9 IDE
ODP
Getting your project_started
PDF
Making sense of streaming
PDF
The Frontend Developer Landscape Explained and the Rise of Advanced Frontend ...
PDF
SOA.2020
PPTX
ChatBots for self-service DevOps
PDF
Add a backend and deploy!
PPT
icebreakerwithdevops-150218112943-conversion-gate02
PPTX
Open NTF OpenSource is collaboration at its best and matters
PPTX
Project management frameworks for software developing
React web development
BelTech 2017 - Building Quality in the Browser
Extreme Programming - to the next-level
Develop 4 Developers
Automated Performance Testing
Introduction to Automated Testing
Stripe con 2021 UI stack
Vagrant + SaltStack + Django - Ararat Poghosyan - DM10
The JAMStack (Javascript, APIs, Markup).
React Webinar With CodePolitan
Saying goodbye to localhost - developing in the cloud with Cloud9 IDE
Getting your project_started
Making sense of streaming
The Frontend Developer Landscape Explained and the Rise of Advanced Frontend ...
SOA.2020
ChatBots for self-service DevOps
Add a backend and deploy!
icebreakerwithdevops-150218112943-conversion-gate02
Open NTF OpenSource is collaboration at its best and matters
Project management frameworks for software developing
Ad

Similar to Modern Messaging for Distributed Systems (8)

PPTX
NServiceBus - introduction to a message based distributed architecture
PPTX
Designing distributed, scalable and reliable systems using NServiceBus
PDF
Rigadevdays - Communication in a microservice architecture
PDF
Message Queues at salesforce.com
PDF
Devit - forget about http requests
PPT
Lecture 3.ppt of cs field using AI and machine management
PPTX
Optimizing communication
PPT
Distributed OPERATING SYSTEM FOR BACHELOR OF BUSINESS INFORMATION TECHNOLOGY
NServiceBus - introduction to a message based distributed architecture
Designing distributed, scalable and reliable systems using NServiceBus
Rigadevdays - Communication in a microservice architecture
Message Queues at salesforce.com
Devit - forget about http requests
Lecture 3.ppt of cs field using AI and machine management
Optimizing communication
Distributed OPERATING SYSTEM FOR BACHELOR OF BUSINESS INFORMATION TECHNOLOGY
Ad

Recently uploaded (20)

PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
System and Network Administraation Chapter 3
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
Nekopoi APK 2025 free lastest update
PPTX
Online Work Permit System for Fast Permit Processing
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PPTX
Introduction to Artificial Intelligence
PDF
Softaken Excel to vCard Converter Software.pdf
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PDF
AI in Product Development-omnex systems
PPT
Introduction Database Management System for Course Database
PDF
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
PPTX
Operating system designcfffgfgggggggvggggggggg
PDF
medical staffing services at VALiNTRY
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PPTX
ISO 45001 Occupational Health and Safety Management System
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PPTX
history of c programming in notes for students .pptx
How Creative Agencies Leverage Project Management Software.pdf
System and Network Administraation Chapter 3
Wondershare Filmora 15 Crack With Activation Key [2025
Nekopoi APK 2025 free lastest update
Online Work Permit System for Fast Permit Processing
How to Migrate SBCGlobal Email to Yahoo Easily
Introduction to Artificial Intelligence
Softaken Excel to vCard Converter Software.pdf
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
AI in Product Development-omnex systems
Introduction Database Management System for Course Database
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
Operating system designcfffgfgggggggvggggggggg
medical staffing services at VALiNTRY
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
ISO 45001 Occupational Health and Safety Management System
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Internet Downloader Manager (IDM) Crack 6.42 Build 41
history of c programming in notes for students .pptx

Modern Messaging for Distributed Systems