Computer Systems Performance
In this course, you will learn how to evaluate the performance of a computer system.
The course combines a focus on low-level system components (hardware, operating system, etc.) with the analysis of complex data systems.
In a world that requires near-instant response times and increasingly faster access to very large volumes of business-critical data, delays cost money.
Data scientists expect high-performance from their data systems in order to reduce time to insight.
Software and DevOps engineers are expected to continuously improve the performance of IT systems.
Oftentimes, performance profiles can uncover the effects of design or implementation bugs.
In this class, students will learn how to design and conduct performance experiments and how to troubleshoot existing complex data systems.
Formal prerequisitesStudents should have taken introductory courses on database systems and operating systems, and should be familiar with C or C++ and Java programming.
Intended learning outcomes
After the course, the student should be able to:
- Design and conduct performance evaluation experiments
- Formulate hypothesis about the causes of poor performance across different layers of a data system’s stack (i.e., data management components, operating system, file system, network, hardware).
- Select appropriate set of tools for troubleshooting performance problems.
- Analyze the performance of a complex real-world data system.
Ordinary examExam type:
D: Submission of written work with following oral, Internal (7-point scale)
D22: Submission with following oral exam supplemented by the submission.