This course provides an introduction to distributed systems, primarily through a focus on the design and development of software that transmits information across networks. Topics will include some but, perhaps, not all of the following: the architecture of distributed systems; networking; synchronous and asynchronous protocols network programming; remote procedure calls; threading and shared memory concurrency; cryptography and security.
Java Network Programming (4th edition), E. R. Harold. O'Reilly & Associates, 2013, Print ISBN: 978-1449357672.
The textbook is not required and no reading assignments will be given from it. It is a useful resource for learning the programming techniques in which you must develop basic proficiency in order to pass this course.
CSC 301, 383, or CSC 393; and CSC 374
During classes, I will be in my office, CDM 838, as follows:
During Finals week, I will be in my office as follows:
Overview
This course focuses on the implementation of distributed systems using a system level library. The programming languages used will be Python and Java. Ongoing programming projects will serve as the main focus on the course. Additionally, quizzes covering various aspects of networking and related topics will also be assigned. Your understanding of the material will be tested through these assignments and a final project. Further details will be posted on the class website, which is on Desire2Learn (D2L).
Approach
Exercises
Quizzes
Grading
Each student is expected to turn in original work for the assignments and final project. Copying code or other documents from another person is considered a serious violation of the university's academic integrity policy (see below).
Week | Date | Topics |
---|---|---|
1 | Sep. 6 | Distributed systems in action |
Sep. 11 | Interprocess Communication(IPC); synchronous sockets programming | |
2 | Sep. 13 | Application Level Protocols intro |
Sep. 18 | Asynchronous programming: Threading and concurrency. Last day to drop without penalty! |
|
3 | Sep. 20 | Asynchronous programming: Threading and concurrency (cont.); networking basics and tools |
Sep. 25 | Local networks; how the Internet Works | |
4 | Sep. 27 | How the Internet Works (cont.); networking protocols: IP, TCP, and UDP |
Oct. 2 | Application Level Protocols: HTTP | |
5 | Oct. 4 | Application Level Protocols: Wire protocols |
Oct. 9 | Remote Method Invocation(RMI) | |
6 | Oct. 11 | Network Address Translation |
Oct. 16 | Scalability and large systems: failover and load balancing | |
7 | Oct. 18 | Content servers: Akamai; cloud computing; Peer to Peer Applications: BitTorrent |
Oct. 23 | non-IP based distributed systems: Cellular data Last day to withdraw without receiving a grade. |
|
8 | Oct. 25 | Firewalls |
Oct. 30 | Transport Layer Security(TLS); IPsec | |
9 | Nov. 1 | Authentication and Authorization: Kerberos |
Nov. 6 | (Parkinson's Law) | |
10 | Nov. 8 | (Parkinson's Law) |
Nov. 13 | Security: SQL Injection; Security: HTML and Cross Site Scripting (XSS); Security: Authentication and Public Key Infrastructure | |
Final Exam | Nov. 20 | Final project due by 11:59pm |
Attendance is optional although encouraged.
This course will be subject to the university's academic integrity policy. More information can be found at http://academicintegrity.depaul.edu/. If you have any questions be sure to consult with your professor.
All students are required to manage their class schedules each term in accordance with the deadlines for enrolling and withdrawing as indicated in the University Academic Calendar. Information on enrollment, withdrawal, grading and incompletes can be found at: http://cdm.depaul.edu/enrollment.
Students who feel they may need an accommodation based on the impact of a disability should contact the instructor privately to discuss their specific needs. All discussions will remain confidential. To ensure that you receive the most appropriate accommodation based on your needs, contact the instructor as early as possible in the quarter (preferably within the first week of class), and make sure that you have contacted the Center for Students with Disabilities (CSD) at: csd@depaul.edu.
Lewis Center 1420, 25 East Jackson Blvd.
Phone number: (312)362-8002
Fax: (312)362-6544
TTY: (773)325.7296
Evaluations are a way for students to provide valuable feedback regarding their instructor and the course. Detailed feedback will enable the instructor to continuously tailor teaching methods and course content to meet the learning goals of the course and the academic needs of the students. They are a requirement of the course and are key to continue to provide you with the highest quality of teaching. The evaluations are anonymous; the instructor and administration do not track who entered what responses. A program is used to check if the student completed the evaluations, but the evaluation is completely separate from the student’s identity. Since 100% participation is our goal, students are sent periodic reminders over three weeks. Students do not receive reminders once they complete the evaluation. Students complete the evaluation online in CampusConnect.
This syllabus is subject to change as necessary during the quarter. If a change occurs, it will be thoroughly addressed during class, posted under Announcements in D2L and sent via email.
Policies of the school are explained on the webpage for this course on my.cdm.depaul.edu.