Course syllabus

Distribuerade system fk.

2025, LP3 – 7.5 hec (hp)
TDA297 (CTH), DIT290 (GU)

Chalmers University of Technology and Gothenburg University

Course Examiner and responsible for the course:

Philippas Tsigas, tsigas [at] chalmers [dot] se

Course Assistants:

  • Jacob Garby, garby [at] chalmers [dot] se
  • Kåre von Geijer, karev [at] chalmers [dot] se

TA office hours for assistance on the lab:

Every group has to (MANDATORY) book a slot for the lab from the provided times in the course calendar. Book one slot per group in the following spreadsheet: Adv distributed systems sign-up.xlsx by writing your group number somewhere in the table.

You need to choose a time slot no later than February 2nd. If you do not choose a time slot by then, your group will be assigned to an empty time slot. It is also possible to drop in to additional lab sessions to ask questions (provided that the day's session is not fully booked).

Email support will not be provided for code-related issues. Please ask your questions during the lab sessions.

Course Hours/Place:

  • Mondays 10:00-11:45, EL42 
  • Wednesdays 10:00-11:45, EL42 or EL41 or EL43 
  • Friday 10:00-11:45, EL41 or EL42 or EC or SB-L200

Please check TimeEdit for the exact lecture room location.

The course starts on Monday, January 20th. 

Please check frequently the Course Schedule for updates. 

Lab:

The lab is to be done in groups of 2 and is due on the 23th of February 2025.

Homework assignment:

The homework assignment is to be done in the same groups of 2. There are multiple deadlines for this assignment and the first one (paper selection) is due 2nd of February 2025. More information here.

Βonus:

The homework assignment and the lab may give you up to 5 points each for the exam. Check the homework assignment and lab pages for more info. 

Literature:

We will use the Fifth Edition of the book titled "Distributed Systems: Concepts and Design" written by: George Coulouris, Jean Dollimore, Tim Kindberg and Gordon Blair, and published by Addison-Wesley, ISBN-10: 0132143011, ISBN-13: 9780132143011. For special themes we will use additional literature items (scientific papers), which will be specified/distributed during the course and, whenever possible, will be made available via the webpage of the course.

Slides:

The slides of the lectures will be published gradually after each lecture in the Course Schedule and in the respective Documents folder.
To prepare prepare for the lecture you can access the slides from last year in Files.

Reading Material:

For the exam, you have to study:

Reading material for the homework assignment can be found here. Also, you can find some old exams, that include March 2022 exams and answers, here.

Course Description

Distributed systems is a popular and powerful computing paradigm. Their importance increases as networked computers become more common than free-standing ones, especially since many different types of computers can be found in networks.

In this course we will see the points of inherent difference and strength of distributed systems compared with sequential or strongly-coupled systems; consequently, we will also study the issues and problems that have to be addressed and solved efficiently for these differences to be taken advantage of, so that the system retains its strength and high potential. This course discusses the fundamentals of distributed systems.

The objective of the course is for students to understand the theoretical principles and practical considerations of distributed systems. By the end of the course, students should be able to reason about various concepts such as consistency, durability, availability, fault tolerance, and replication. By the end of the course, students should be able to understand and reason about the limits that asynchrony, failures and concurrency bring into the distributed system designs. 

In particular, we will address and study the following issues in distributed systems:

  1. Reliable and atomic broadcast
  2. Replication and Consistency: The advantages and costs of replicating data: the potential improvement in response times and reliability, and the extra communication costs involved in keeping data consistent.
  3. Fault-tolerant Agreement in Distributed Systems (a very special and significant problem, since it is a key issue in most synchronization and coordination problems in distributed systems) Study of the basic impossibility results and discuss their implications; proceed with solutions and protocols for systems with certain strengths and design structures.
  4. Resource allocation
  5. Analysis and Design of Distributed Algorithms
  6. Blockchain

When it comes to the topics, there is an overlap on the topics discussed in this course and in the introductory course on Distributed Systems. The difference is on the objectives and the depth of the reasoning tools discussed.

Course Evaluation

A team of students representing the GU-CS students, the CTH International Master's program students, and the "local" CTH students is formed. The team's task is to:
- Provide feedback from students
- take part in mid- and final-evaluation meetings
- write meeting minutes; and
- together with the teacher compile the final evaluation report.

The team is initially comprised of the following students (If you want to join lets us know. The list will be finalized during the first week of the course):

MPCSN  ackemo@student.chalmers.se    William Ackemo
MPBDP  almedom@student.chalmers.se  Benhur Almedom
MPCSN  victoreb@student.chalmers.se    Victor Ebbesson
MPCSN  shujaul@student.chalmers.se      Md Shujaul Haque
MPCSN   jesperku@student.chalmers.se   Jesper Kullberg

Course summary:

Course Summary
Date Details Due