The goal of this Lab is to:

  1. gain experience in designing experiments that measure the performance of complex software systems,
  2. process and analyze the results,
  3. build models that describe the behavior of the system.

In order to achieve these goals, you will have deploy applications and measure their behavior in a cloud environment. Some coding and scripting will also be required. Finally, the experimental results and the models will be used to determine the components of the system that are the bottleneck for performance.

The skills acquired in the Lab shall be relevant to a wide variety of career paths: students who will later pursue a PhD in Systems topics, Data Scientists who will have to work with large distributed processing pipelines, Software Engineers and DevOps who will have to work on improving the performance of IT systems.

To achieve the above goals, we will, on the one hand, review the relevant theory (e.g., Statistical methods, Little's Law, Queuing Theory) and, on the other hand, deploy and modify data-intensive applications in cloud environments. 

Textbook (will provide excerpts):

R. Jain, "The Art of Computer Systems Performance Analysis: Techniques for Experimental Design, Measurement, Simulation, and Modeling," Wiley- Interscience, New York, NY, April 1991, ISBN:0471503361