tyuchn / bsds-6650

CS6650 Building Scalable Distributed Systems

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Building Scalable Distributed Systems

CS6650 Fall 2021

Instructor: Ian Gorton, Khoury College of Computer Sciences, Northeastern University, Seattle Campus

Logistics

This is an onground class taught on the Seattle Campus, 225 Terry Ave n, room 307, Tuesday 3-6.15pm

Course Lead

Ian Gorton - i.gorton(at)northeastern.edu

Office Hours - Wednesday 2-4pm (PST)

Super Talented Teaching Assistants

  • Tiffany Marthin - marthin.t(at)northeastern.edu
    • Thursday 3-5pm (Room 142 in 401 building)
  • Heejun You - you.he(at)northeastern.edu
    • Tuesday 1-3pm (Room 307 in 225 building)

Overview

This course will cover the essential elements of distributed, concurrent systems and build upon that knowledge with engineering principles and practical experience with state-of-the-art technologies and methods for building scalable systems. Scalability is an essential quality of Internet-facing systems, and requires specialized skills and knowledge to build systems that scale at low cost.

Course Delivery

This site contains all the informtion for the course, except the quiz questions. Class will meet each week for 3 hour 15 mins. Classes will be a mix of lectures and labs.

Course Book

The book for the course, Concurrency and Scalability for Distributed Syetms, is in development.

The first 11 chapters should be progressively available online here.

You should be able to access this and all O'Reilly books through the library.

Assessment

  • There are 4 individual assigments. They total 70% of the final grade.
  • There are 4 quizes. They combine to add up to the remianing 30% of the grade. The first 3 will cover the materials in the previous 3 week's classes. The last quiz will have questions that cover the whole course. Each quiz will be allocated 45 minutes and be available at the start of the class in which it is scheduled.

Course Content

Modules

Week Topic Date
1 Introduction to Scalable Distributed Systems 9/14
2 Concurrency 9/21
3 Distributed Systems Architecture Whirlwind Tour 9/28
4 Distributed Systems Fundamentals 10/5
5 Scalable Service Design 10/12
6 Asynchronous Systems 10/19
7 Microservices 10/26
8 Data Replication, Partitioning and Eventual Consistency 11/2
9 Strong Consistency and Distributed Databases 11/9
10 NoSQL Databases 11/16
11 Serverless Processing Systems 11/23
12 Stream Processing 11/30
13 Final Quiz 12/7

Assignments

Submission instructions and exact deadlines are on the course Canvas site.

Assignment Topic Due Date
1 Concurrency and Client-server 10/6
2 Building the Server 10/27
3 Adding the Data Layer 11/17
4 Scaling the System 12/10

Quizzes

Quizzes are held on Tuesdays, in class. Once you start you must finish within 45 minutes.

Quiz Date
1 10/12
2 11/2
3 11/23
4 Last class!

Reading

In addition to the course book, the following are great resources, and can be excellent references for this course and your future career.

  • Java Concurrency in Practice 1st Edition, Brian Goetz, Tim Peierls, Joshua Bloch, Joseph Bowbeer, David Holmes, Doug Lea
  • Distributed systems : concepts and design, Coulouris, George F. ; Dollimore, Jean. ; Kindberg, Tim. ; Blair, Gordon. Harlow, England ; Addison-Wesley c2012
  • Designing Data-Intensive Applications: The Big Ideas Behind Reliable, Scalable, and Maintainable Systems, Martin Kleppmann, O'Reilly

Policies

Late Submission If you need more time, come beg :). Communications usually give a positive outcome. Without warning, you'll lose 5% of your final grade each day overdue.

Missed Quizzes Quizzes last approximately 45 minutes. If you are not able to attend and take the quiz at the same time as others, you must let me know in advance. Failure to do this will result in a zero for the quiz you miss.

Do your own work You know the rules. Helping each other out is fine, but design and build your own system. Any unwarrented collaboration will result in a zero grade for the assignment.

About

CS6650 Building Scalable Distributed Systems


Languages

Language:Java 100.0%