my_digital_garden/content/ASCN/T - Aula 2.md

1.8 KiB

18 Setembro 2023 - #ASCN

Why distributed systems?

  • Modularity, decoupling different concerns.
  • Performance.
  • Dependability

How to distribute?

1. Monolythic system

2. Distributed systems

  • Main distribution concerns:
    1. Replication
    2. Partitioning
    3. Service-orientation
  • All of these address scaling out a service/application.
  • Not mutually exclusive, can be combined.

2.1 Replication

  • Architecture: Replication.excalidraw
  • Multiple copies of the same data and functionality
  • Addresses resilience and scale-out

2.2 Partitioning

  • Architecture: Partitioning.excalidraw
  • A server is split horizontally (Sharding).
  • Addresses scale-out.
  • Can be applied to computation, data, ...

2.3 SOA - Service-Oriented Architecture

  • Architecture: SOA.excalidraw
  • Addresses scale-out and modularity.
  • Example: micro-services.

2.3.1 Microservices

  • Each service implements specific functionality.
  • Services can scale independently.
  • Decomposition may be troublesome: how micro is micro?
  • Consistency.
  • Complex deployment and testing

Distributed architectures

1. Client-server

  • Architecture: client-server.excalidraw
  • Functionality and data are in the server.
  • A stub runs embedded in the client.
  • The stub is part of the server software package
    • E.g., the Web (“protocol” is HTTP)

2. Proxy Server

  • Architecture: proxy.excalidraw
  • Multiple servers can be used transparently.
  • The proxy is a performance and availability bottleneck.
    • E.g. MongoDB

3. Master Server

  • Architecture: mas
  • Proxy functions split between stub and master server
  • The proxy is a performance and availability bottleneck.
    • E.g. MongoDB