| 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, Distributed ledgers, Immutability of blocks, Massive replication, UTXO (Unspent Transaction Output), Merkle-tree. |
| 3. Processes |
[3.3] Clients
|
Client Stub, Networked User Interfaces. |
| |
[3.4] Servers
|
Iterative/Concurrent Servers, Stateful/Stateless Servers, Server Clusters, Permanent State, Session State. |
| |
[3.5] Code migration
|
Code Migration, Process Migration, Remote Evaluation (REV), Code-on-Demand (CoD), Mobile Agents (MA), Pre-copy approach, Threads, Containers (Vservers). |
| 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.3] Message-oriented communication
|
Message Passing, Transient vs. Persistent Communication, Message Queuing Systems (MOM), Message Broker, AMQP, ZeroMQ. |
| |
[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, Berkeley Algorithm, 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
|
Token-based Mutual Exclusion, Permission-based Mutual Exclusion, Centralized Algorithm (Sequencer), Ricart-Agrawala Algorithm, Maekawa’s Algorithm, Token-Ring Algorithm, Deadlock, ZooKeeper Locking. |
| |
[5.4] Election algorithms - RAFT |
Leader Election Algorithm, Bully Algorithm, Ring Algorithm, RAFT Leader Election, Proof of Work (PoW), Proof of Stake (PoS), Invitation Algorithm. |
| |
[5.5] Gossip-based coordination
|
Aggregation, Peer-Sampling Service (PSS), Cyclon. |
| |
[5.6] Distributed event matching
|
Event Matching, Publish-Subscribe (Topic-based vs. Content-based), Selective Routing. |
| 6. Naming |
[6.2.3] Distributed hash tables
|
Flat Naming, Distributed Hash Tables (DHT), Chord, Forwarding Pointers, Self-Certifying Name. |
| |
[6.3.4] Example: The Domain Name System
|
Structured Naming, Domain Name System (DNS), Name Resolution (Iterative, Recursive), Zone, DNSSEC. |
| |
[6.3.5] Example: The Network File System
|
Network File System (NFS), File Handle, Mount protocol. |
| |
Related Concepts |
Attribute-based Naming, Directory Services, LDAP, Information-Centric Networking (ICN), Named-Data Networking (NDN). |
| 7. Consistency and Replication |
[7.2] Data-centric consistency models
|
Sequential Consistency, Causal Consistency, Entry Consistency, Eventual Consistency, Continuous Consistency (Conit), Distributed Shared Memory (DSM), Conflict-Free Replicated Data Type (CRDT), Coherence Model. |
| |
[7.3] Client-centric consistency models
|
Monotonic Reads, Monotonic Writes, Read Your Writes, Writes Follow Reads, Session consistency. |
| |
[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. |
| |
[7.5] Consistency protocols
|
Primary-based protocols (Remote-write, Primary-Backup), Replicated-write protocols (Active Replication), Quorum-based protocols (Voting), Read-One, Write-All (ROWA), Cache-coherence protocols, Leases. |
| 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), HotStuff, Consensus in blockchain systems, Permissioned/Permissionless blockchains, Cryptographic linking (in BGP context), segwit, taproot, multisig, lightning network, 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, Virtual Synchrony (VSync/Virtuální synchronie), Atomic multicast, Trans Algorithm, Transis algorithm, ISIS. |
| |
[8.5] Distributed commit
|
Distributed Commit, Two-Phase Commit (2PC), Three-Phase Commit (3PC), Recovery, Checkpointing/Distributed Snapshot (Recovery line), Message logging. |