Distributed Systems Academy

Home

banner.png   

Distributed Systems Academy (DSA) teaches both theoretical and practical aspects of implementing distributed systems. Students are introduced to important concepts about distributed system design and use those concepts to implement distributed systems.

Students who successfully complete DSA will understand the following concepts:

  • Principles and concepts of designing and building distributed systems.
  • Introduction to architectures for distributed computation including map-reduce, client-server, peer-to-peer, and event-driven.
  • Cloud computing and APIs.
  • Failure modes for distributed systems and how to mitigate them
  • Reliability, availability, and scalability of large applications.
  • Peer-to-peer distributed system architecture and principles including concepts such as 
    • Asynchronous interaction patterns (event and message-based interaction)
    • Distributed consensus and eventual consistency
    • P2P algorithms including Gossip protocols, Paxos, and byzantine generals problem.
    • Blockchains
    • Conflict-free replicated data types (CRDTs)

Course Information

Course Modules


Photo Credit: Bees in a bee hive Links to an external site. from USDA (CC BY 2.0)

CC Attribution Non-Commercial Share Alike This course content is offered under a CC Attribution Non-Commercial Share Alike Links to an external site. license. Content in this course can be considered under this license unless otherwise noted.