Announcements
- First class is on 9/2, see you soon!
- All class-related announcements and discussion will be on Piazza.
Class schedule: Tuesday 5:10 - 7:00pm (CIWW 312) .
Class instructor: Jinyang Li (Office hour: Wed 4-5pm)
Instructional assistance: Yang Cui (Office hour: Mon 4-5pm)
Discussions: Piazza
Course information
Distributed systems help programmers aggregate the resource of
many networked computers to construct highly available and scalable services, such as
peta-byte storage, massively parallel computation.
This class teaches the abstractions, design and implementation techniques that
allow you to build fast, scalable, fault-tolerant distributed systems. Topics
include multithreading, network programming, consistency, naming, fault
tolerance, and security and several case studies of distributed systems.
This class is a graduate-level course, but undergraduate students are welcome!
The course consists of lectures, a series of
programming labs and a final project.
This class satisfies
the Ph.D. breadth requirement in Systems
and also serves as a M.S. capstone course.
Prerequisites:
1. Undergraduate Operating Systems or Computer Systems Organization
2. Programming experience in C/C++ is important for the programming labs
Useful Books
The following books may help provide background help with lab programming. None of them are required. They are listed in rough order of usefulness.
- Principles of Computer System Design. Jerome Saltzer and M. Frans Kaashoek, Morgan Kaufmann.
- Distributed Systems: Principles and Paradigms, Andrew Tanenbaum and Maarten van Steen, Prentice Hall.
- Advanced Programming in the UNIX Environment. W. Richard Stevens.
- The C++ Programming Language. Bjarne Stroustrup. Addison Wesley.
- UNIX Network Programming. Volume 1: Networking APIs: Sockets and XTI. W. Richard Stevens.
- Modern Operating Systems. Andrew Tanenbaum. Prentice Hall.
Questions or comments? email dss-staff@cs.nyu.edu
Policy on academic integrity