DEV Community

Cover image for Just how effective is web server caching? Very.
David J Eddy
David J Eddy

Posted on

14 5

Just how effective is web server caching? Very.

Running a high load website can be used as a test case for the negative effects of stress over long periods of time has on the human body. Mental pressure, hair loss, lack of sleep, burn out, social disconnection. Thankfully it does not have to be like this. Running a high load web CMS does not have to be stressful. Come with me as I setup and Wordpress CMS to handle 1000 users per minute for less than the cost of lunch.

Note: This is not a HA (high-availability) configuration and is NOT production ready. Thought, it is a solid starting point for one.

Tools for the toolbelt!

The tools this solution leverages are pretty mundane. No fancy HAProxy cluster with multi-cloud CDN edge locations here. Simplicity is king. A basic, bottom dollar Lightsail instance running an Ubuntu Server. Total cost to run the minimal infrastructure: about $10/USD month. How much you will pay in data transfer depends on you.

Tech Stack:

  • AWS IaaS provider
  • Lightsail - Compute Instance
  • Ansible, Terraform, and Gatling for testing

Install all the things (programs)

To make setting up and testing different configurations as easy as possible I created a simple Terraform configuration and used Ansible to install and configure the different. The three config under test are no caching, Wordpress plugin caching and Nginx micro caching. Nothing to fancy there. If you are interested here is the GiT repo.

Caching, hoah, what is it good for!

Every time a user requests a page the request is processed by Nginx (the web server), then the interpreter process the Wordpress PHP logic and outputs the HTML/JS/CSS. Passing the payload to Nginx to be returned to the requesting user. Two steps along this process can be speed up massively with caching. Caching keeps a copy of the response for a given amount of time, returning the stored copy rather than re-processing the entire request every time.

Two caching settings we will need to implement: Wordpress via the WP Super Cache plugin and Nginx micro caching.

Since we will be running PHP 7.x OPcache is enabled by default so we do not need to worry about that now (unlike with PHP 5.x).

Party Picture time!

All configurations below have a base line of 1000 users over a 1 minute time length on Ubuntu 18.04 running latest Nginx, MySQL, and PHP as of 2018-11-02.

First up, lets look at a basic LEMP install with no caching at all.

Wordpress CMS, no caching.

Looks ugly after about 200 concurrent users.

Wow, that's rough. But is gives us a base line. Looks like the machine can handle around 200 users per second before things start going bad.

Installing and configuring the Wordpress caching with the below settings we test a type of application level caching.

Highest rated Wordpress cache plugin, here's the settings.

A bit better, but was really hoping for better,

So the application level caching brought down the failure rate; but not really enough to matter.

Lastly, I tore down the setup and stood up a fresh setup. This time with Nginx micro caching with a one minute life time.

Now this is more like it.

Request in, response out; fast.

Boom! Look at that! Sure, still some errors but WOW! 0 to 1000 linear increase in users over a minute and it ticks along like someones business. I noticed the max concurrent users was much lower given the Nginx cache. After digging in I found that it was due to the requests being completed and not clogging up the system.

Wrapping it up boss.

1000 users per second at the end of a minute and the little web server was ticking along like nothing was happening. I'd consider that high performance given the little effort it takes to configure.

So what does performance do for the business? Lowers cost of operation. The less time and hardware resources each requests requires, the more requests for a given piece of hardware can handle. This directly translates to lower operating cost for a given workload. Performance is king, within reason.

Leave a comment below and let me know what you think; or even your experience with performance tuning.

Image of Bright Data

High-Quality Data for AI – Access diverse datasets ready for your ML models.

Browse our extensive library of pre-collected datasets tailored for various AI and ML projects.

Explore Datasets

Top comments (6)

Collapse
 
dallgoot profile image
dallgoot

I love digging performance issues and seeing experience feedback.
One thing to make this article perfect : links or brief description on your actions eg. what is required for nginx caching.
So that users are pointed to the correct path ;)

Collapse
 
david_j_eddy profile image
David J Eddy

Excellent point @dallgoot ! If you are interested right now the caching Nginx configuration is included in the repo. I'll do a seperate write about how to configure it outside this project soon(tm). Thanks.

Collapse
 
david_j_eddy profile image
David J Eddy

That is a very valid option for Wordpress @tux0r , thank you for the resource.

Collapse
 
rhymes profile image
rhymes

Loved the Edwin Starr reference :D

Collapse
 
david_j_eddy profile image
David J Eddy

Was hoping someone would get it. Sometimes by references are so abstract they only work in my head. hope you enjoyed the article as well. ;)

Cloudinary image

Zoom pan, gen fill, restore, overlay, upscale, crop, resize...

Chain advanced transformations through a set of image and video APIs while optimizing assets by 90%.

Explore

👋 Kindness is contagious

Dive into an ocean of knowledge with this thought-provoking post, revered deeply within the supportive DEV Community. Developers of all levels are welcome to join and enhance our collective intelligence.

Saying a simple "thank you" can brighten someone's day. Share your gratitude in the comments below!

On DEV, sharing ideas eases our path and fortifies our community connections. Found this helpful? Sending a quick thanks to the author can be profoundly valued.

Okay