| 1. Introduction |
(skim through entire chapter) |
Distributed vs. Decentralized systems, Resource Sharing, Design Goals (Openness, Dependability, Security, Scalability), Distribution Transparency (Access, Location, Concurrency, Failure, Migration, Relocation, Replication), Partial Failure, Scaling Techniques (Partitioning, Replication), Leslie Lamport’s definition, Lack of trust (relevance for decentralized systems). |
| 2. Architectures |
[2.1] Architectural styles
|
Layered Architectures, Service-Oriented Architecture (SOA), RESTful Architecture, Microservices, Shared Data Space, Linda tuple spaces. |
| |
[2.2] Middleware and distributed systems
|
Middleware Layer, ZeroMQ, AMQP (Advanced Message Queuing Protocol). |
| |
[2.3] Layered-system architectures
|
Client-Server Architecture, Multitiered Architectures, Thin Client. |
| |
[2.4] Symmetrically distributed system architectures
|
Peer-to-Peer (P2P), Overlay Network, Distributed Hash Tables (DHT), Chord system, Flooding, Random Walk. |
| |
[2.5] Hybrid systems architectures
|
Cloud Computing, Infrastructure-as-a-Service (IaaS), Platform-as-a-Service (PaaS), Blockchain architectures |
| 4. Communication |
[4.2] RPC
|
Remote Procedure Call (RPC), Marshaling, Interface Definition Language (IDL), Parameter passing (copy/restore), RPC semantics (at-least-once, at-most-once), Orphans, Orphan extermination, Reincarnation, Expiration. |
| |
[4.4] Multicast communication
|
Application-level multicasting, Flooding, Gossip-based Data Dissemination (Epidemic protocols), Epidemic models, Anti-entropy. |
| 5. Coordination |
[5.1] Clock synchronization
|
Physical clocks, NTP, Reference Broadcast Synchronization (RBS), Coordinated Universal Time (UTC). |
| |
[5.2] Logical clocks
|
Logical Clocks, Causal Dependency, Lamport’s Logical Clocks (Timestamp), Vector Clocks, Totally Ordered Multicasting. |
| |
[5.3] Mutual exclusion
|
Centralized Algorithm (Sequencer), Ricart-Agrawala Algorithm,Token-Ring Algorithm, Decentralized algorithm, Deadlock, ZooKeeper Locking. |
| |
[5.4] Election algorithms - RAFT
|
Bully Algorithm, Ring Algorithm, RAFT Leader Election, Proof of Work (PoW), Proof of Stake (PoS), Invitation Algorithm.
|
| 6. Naming |
[6.2.3] Distributed hash tables
|
Flat Naming, Distributed Hash Tables (DHT), Chord, Forwarding Pointers, Self-Certifying Name. |
| 7. Consistency and Replication |
[7.2] Data-centric consistency models
|
Sequential Consistency, Causal Consistency, Entry Consistency, (Strong) Eventual Consistency, Weak Consistency, Continuous Consistency (Conit), Distributed Shared Memory (DSM), Conflict-Free Replicated Data Type (CRDT), Coherence Model.
|
| |
[7.4] Replica management
|
Replica placement, Content Distribution Networks (CDN), Permanent/Server-initiated/Client-initiated replicas, Push-based vs. Pull-based Protocols, Content-blind caching. |
| 8. Fault tolerance |
[8.1] Introduction
|
Failure Models (Crash, Omission, Timing, Arbitrary/Byzantine Failures), Redundancy (Information, Physical, Time), Dependability (Availability, Reliability, Safety). |
| |
[8.2] Process resilience (Paxos, RAFT, byzantine agreement problem) |
Process Groups, Consensus, Paxos (Proposer, Acceptor, Learner, Ballot numbers), RAFT (Term, Log Replication, AppendEntries), Byzantine Generals Problem (BGP), Practical Byzantine Fault Tolerance (PBFT), Consensus in blockchain systems, CAP Theorem. |
| |
[8.3] Reliable client-server communication
|
Reliable RPC Semantics, Failure detection, At-least-once semantics, At-most-once semantics, Idempotent operation. |
| |
[8.4] Reliable group communication (virtual synchrony) |
Reliable multicasting, Feedback Implosion, Atomic multicast, Causally ordered multicast, Virtual Synchrony. |
| |
[8.5] Distributed commit
|
Distributed Commit, Two-Phase Commit (2PC), Three-Phase Commit (3PC). |
| |
[8.6.2] Checkpointing
|
Checkpointing, distributed snapshot, independent chackpointing
|