Explaining distributed systems like I'm five

Michele Riva

MicheleRivaCode

The idea for this talk started during an online course

MicheleRivaCode

The idea for this talk started during an online course

Gabriele

Me

Friends

MicheleRivaCode

What problems do distributed systems solve?

MicheleRivaCode

Create an API that uploads a large CSV file (>10GB) to a server, then read the file, normalize the data, and store it into a database

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

What if we have dozens of concurrent uploads?

MicheleRivaCode

Once we start uploading and processing a few large files, we'll run out of memory

MicheleRivaCode

MicheleRivaCode

The ice cream scenario

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

How do we currently deal with large amounts of people?

MicheleRivaCode

With queues!

MicheleRivaCode

With queues!

But what if there's a *lot* of people?

MicheleRivaCode

We hire a security guard

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

When it comes to software architecture, things gets a bit harder...

MicheleRivaCode

A collection of indipendent computers that appear to its users as one computer

A distributed system is

(Andrew Tanenbaum)

MicheleRivaCode

MicheleRivaCode

  • Computers operate concurrently

MicheleRivaCode

MicheleRivaCode

  • Computers operate concurrently
  • Computers fail independently

MicheleRivaCode

MicheleRivaCode

  • Computers operate concurrently
  • Computers fail independently
  • Computers do not share a global clock

MicheleRivaCode

Source of truth

MicheleRivaCode

Source of truth

Sync request

Sync request

MicheleRivaCode

Source of truth

Time response

Time response

MicheleRivaCode

Source of truth

Time response

Time response

Network time protocol (NTP)

Precision time protocol (PTP)

MicheleRivaCode

  • Computers operate concurrently
  • Computers fail independently
  • Computers do not share a global clock

The solution needs to follow the following rules

MicheleRivaCode

Is uploading a large file to a server a good option?

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

  • Do computers operate concurrently?
  • Do computers fail independently?
  • Do computers share a global clock?

Have we respected the rules?

MicheleRivaCode

So what problems did we solve?

Michele Riva

Senior Software Architect @NearForm

Google Developer Expert

Microsoft MVP

MicheleRivaCode

MicheleRivaCode

MicheleRivaCode

@MicheleRiva

@MicheleRivaCode

/in/MicheleRiva95

www.micheleriva.dev

Explaining distributed systems like I'm five

By Michele Riva

Explaining distributed systems like I'm five

  • 377