COEN6731 Winter 2025
Distributed Software Systems

General Information
Course description
Welcome to COEN 6731: Distributed Software Systems! Distributed systems form the backbone of many essential services that we rely on every day, from healthcare and banking to financial services and online platforms.
In this course, we will explore foundational concepts in distributed systems, including concurrency, security, fault tolerance, networking principles, remote procedure calls (RPC), peer-to-peer architectures, coordination and agreement protocols, MapReduce frameworks, distributed transactions, and data replication. By understanding these core principles, students will gain the necessary skills to design and build reliable, scalable, and secure distributed applications.
This year, COEN 6731 will feature a special focus on blockchain technologies, a transformative innovation that is reshaping industries worldwide. We will examine the key building blocks of blockchain systems, with a particular emphasis on consensus mechanisms and fault tolerance. Through this focus, students will gain insights into how blockchain technologies are applied across various domains and understand the challenges of achieving trust and coordination in distributed environments.
When and where
Lectures
-
Time: Wednesday 2:45pm-5:30pm
-
Location: MB 3.445 SGW
Course requirements
Marking scheme
-
Presentations and deliverables (30%)
-
In-class presentation
-
Slides
-
-
Participation and discussion (10%)
-
Course project (60%)
-
Proposal one pager and presentation (10%)
-
Progress report presentation (5%)
-
Final presentation and demo (20%)
-
Final report (25%)
-
Presentation and deliverables
Complete the form for paper selection preferences and team signup and read the instructions here.
Course project
The description and guidelines of the course project are available here. Submission deadlines are stated below:
-
Project proposal report and presentation slides
-
Submit to Moodle by Feb 12, 11:59 pm (lecture day in Week 5).
-
-
Progress report slides
-
Submit to Moodle by March 12, 11:59 pm (lecture day in Week 8).
-
-
Final project report and slides
-
Submit your slides to Moodle by April 9, 11:59 pm (last lecture).
-
Submit your final report to Moodle by April 14, 11:59 pm.
-
Lecture
Schedule
This is a tentative schedule, which will likely change as the course goes on.
Week 1
-
Topics: Introductions, fundamentals, and time in DS.
-
Lecture: [Slides]
Week 2
-
Topics: Coordination, Agreement, and Paxos
-
Lecture: [Slides]
Week 3
-
Topics: RPCs and Raft
-
Lecture: [Slides]
-
Raft: https://raft.github.io/
Week 4
-
Topics: Blockchains, Byzantine fault tolerance (Proof-of-Work and PBFT)
-
Lecture: [Slides]
Week 5
-
Topics: Cabinet and demo [Paper]
-
Project proposal presentation
Week 6 (Paper presentations start)
-
Topics
-
EPaxos [SOSP'13], There Is More Consensus in Egalitarian Parliaments. [Link]
-
[Slides]
-
-
NoPaxos [OSDI'16], Just Say NO to Paxos Overhead: Replacing Consensus with Network Ordering. [Link]
-
[Slides]
-
-
HovercRaft [Eurosys'20], HovercRaft: Achieving Scalability and Fault-Tolerance for Microsecond-Scale Datacenter Services. [Link]
-
[Slides]
-
-
Week 7
-
Topics
-
HotStuff [PODC'19], HotStuff: BFT consensus with linearity and responsiveness. [Link1] [Link2] Link2 presents an extended version with evaluation results
-
[Slides]
-
-
Pompe [OSDI'20], Byzantine Ordered Consensus without Byzantine Oligarchy. [Link]
-
[Slides]
-
-
ResilientDB [VLDB'20], ResilientDB: Global Scale Resilient Blockchain Fabric. [Link]
-
[Slides]
-
-
Week 8
-
Topics
-
Project midterm progress presentations
Week 9
-
Topics
Week 10
-
Topics
Week 11
-
Topics
Week 12
-
Final course remarks
-
Final project presentations and demos
Course
Policies
Notice of video recording and sharing
At times during this course, some interactions including students’ participation, may be recorded on video. Course videos and materials belong to the instructors, the University, and/or other sources depending on the specific facts of each situation, and are protected by copyright. For questions about recording and use of videos in which you appear please contact your instructor.