2024 Faculty Courses School of Computing Department of Mathematical and Computing Science Graduate major in Mathematical and Computing Science
Distributed Systems
- Academic unit or major
- Graduate major in Mathematical and Computing Science
- Instructor(s)
- Ryuichi Sakamoto
- Class Format
- Lecture (Face-to-face)
- Media-enhanced courses
- -
- Day of week/Period
(Classrooms) - 7-8 Tue / 7-8 Fri
- Class
- -
- Course Code
- MCS.M429
- Number of credits
- 200
- Course offered
- 2024
- Offered quarter
- 3Q
- Syllabus updated
- Mar 14, 2025
- Language
- English
Syllabus
Course overview and goals
This year, this lecture will be given in English.
This lecture will introduce the architecture, communication, process, naming, consistency, security, and fault tolerance that are the foundations of distributed systems. Students will learn practical aspects of building and operating distributed systems using microservices as examples. Learn about orchestration tools and service meshes for efficient operation of microservices, and experience microservices by introducing Kubernetes and Istio. Furthermore, the course introduces the details of container and network configuration.
Course description and aims
You will be able to acquire the following skills:
1. You will learn about the architecture, processes, communications, security, etc. that support distributed systems.
2. You will be able to operate microservices.
3. You will be able to evaluate and improve the performance of distributed systems.
4. You will be able to debug and analyze distributed systems using service meshes.
5. You will be able to understand and correctly use the container virtualization and network configuration that support microservices.
Keywords
Distributed systems, microservices, fault tolerance, autoscaling, distributed tracing, Kubernetes
Competencies
- Specialist skills
- Intercultural skills
- Communication skills
- Critical thinking skills
- Practical and/or problem-solving skills
Class flow
Lectures will be based on slides. Network programming exercises will be conducted using VMs
Course schedule/Objectives
Course schedule | Objectives | |
---|---|---|
Class 1 | Introduction Learn the overview of distributed systems | Not specified |
Class 2 | Distributed architecture Learn the basics of distributed systems | Not specified |
Class 3 | Processes In distributed systems, there are various ways to use processes depending on the purpose. Learn the details of processes that communicate efficiently. | Network Basics Exercises |
Class 4 | Communication Introduce communication in distributed systems and learn how multiple distributed elements work together. | Not specified |
Class 5 | Introduction to network programming Learn about network programming. Create a simple server and client. | Not specified |
Class 6 | Name resolution Name resolution is necessary to uniquely recognize distributed resources, and learn about naming in distributed systems. | Name Resolution Exercise |
Class 7 | Consistency and replicas Copying and distributing data can improve reliability and performance, but it is important to ensure consistency. Learn about the placement of replicas, which are copies of data, in distributed systems and how to ensure consistency. | Not specified |
Class 8 | Network programming, part 2 Learn about web servers and L4 LB | Report on network programs |
Class 9 | Fault tolerance Introduce failures that can occur in distributed systems and learn how to deal with them. | Not specified |
Class 10 | Security Learn about security in distributed systems. | Not specified |
Class 11 | Microservices Learn about containers and microservices | Not specified |
Class 12 | Monitoring, management, and control of distributed systems Learn about monitoring and management of distributed systems | Distributed Systems Exercises |
Class 13 | Network programming, advanced 1/2 Learn about tracing | Report for Microservice |
Class 14 | Network programming, advanced 2/2 Learn about tracing |
Study advice (preparation and review)
To enhance effective learning, students are encouraged to spend approximately 100 minutes preparing for class and another 100 minutes reviewing class content afterwards (including assignments) for each class.
They should do so by referring to textbooks and other course material.
Textbook(s)
M. van Steen and A.S. Tanenbaum, Distributed Systems, 4th ed., distributed-systems.net, 2023.
https://www.distributed-systems.net/index.php/books/ds4/
Reference books, course materials, etc.
Not specified
Evaluation methods and criteria
- Small practices
- 2 reports
Related courses
- MCS.T233 : Computer Systems
- MCS.T314 : Operating Systems
Prerequisites
Have basic knowledge of network