Skip to main content Link Menu Expand (external link) Document Search Copy Copied

Performance

Test, measure, and comment on the performance of httpserver, forkserver, threadserver, and poolserver. We will use the Apache HTTP server benchmarking tool (ab for short) to load test each server type. You can install ab with sudo apt-get install -y apache2-utils.

  1. Run ./httpserver --files www/.
  2. In a separate terminal window, run ab -n 500 -c 10 http://192.168.162.162:8000/

    This command issues 500 requests at a concurrency level of 10 (meaning it dispatches 10 requests at a time). Read man ab to learn more about the tool. You can type “man ab” in your terminal or your preferred search engine. However, please note that typing “man ab” into Google will also give you defined images of chiseled male abdominal muscles; do so at your own discretion.

    Notice how ab outputs the mean time per request. Take note of this value and comment on how it changes when we change how the server handles requests.

  3. Use ab to load-test forkserver, threadserver, and poolserver. Play around with the n and c variables as well as the size of the thread pool in poolserver.

You no longer have to answer these questions on Gradescope, but test and consider the following questions!

  1. Run ab on httpserver. What happens when n and c grow large?
  2. Run ab on forkserver. What happens when n and c grow large? Compare these results with your answer in the previous question.
  3. Run ab on threadserver. What happens when n and c grow large? Compare these results with your answers in the previous questions.
  4. Run ab on poolserver. What happens when n and c grow large? Compare these results with your answers in the previous questions.