EngineScript automates the process of building a high-performance LEMP server. We've specifically built EngineScript with WordPress users in mind, so the install process will take you from a bare server all the way to a working WordPress installation with Nginx FastCGI cache enabled in about 30 minutes.
EngineScript is meant to be run as root user on a fresh VPS. Initial setup will remove existing Apache, Nginx, PHP, and MySQL installations, so be careful.
As this is a pre-release version, things may be broken.
- A Newly Created VPS (Digital Ocean droplet recommended)
- Ubuntu 22.04
- 64-Bit OS
- Minimum 1GB RAM (2GB+ recommended)
- Cloudflare (free or paid)
- 30 minutes of your time
Run the following command:
wget https://raw.githubusercontent.com/EngineScript/EngineScript/master/setup.sh && bash setup.shAfter the initial setup script has run, you'll need to alter the install options file.
First, retrieve your Cloudflare Global API Key at https://dash.cloudflare.com/profile/api-tokens. Then you'll need to edit the configuration file at /home/EngineScript/enginescript-install-options.txt. Fill this out completely, making sure to change all variables that say PLACEHOLDER.
Run the following command:
es.configOnce you've filled out the configuration file with your personal settings, continue with the main installation process.
Run the following command:
es.installAfter EngineScript is fully installed, type es.menu in console to bring up the EngineScript menu. Choose option 1 to create a new domain.
Domain creation is almost entirely automated, requiring you to only enter the domain name you wish to create. During this automated process, we'll create a unique Nginx vhost file, create new MySQL database, request a new SSL certificate from Cloudflare, download WordPress, install and activate plugins, and assign the applicable data to your wp-config.php.
Before your site is ready to use, you'll need to go into Cloudflare to configure a number of important settings. Follow the steps below to finalize your installation:
- Select your site.
- Click on the SSL/TLS tab.
- Set the SSL mode to Full (Strict).
- Set Always Use HTTPS to Off. (Important: This can cause redirect loops)
- Enable HSTS. (Optional) We recommend enabling HSTS. However, turning off HSTS will make your site unreachable until the Max-Age time expires. This is a setting you want to set once and leave on forever.
- Set Minimum TLS Version to TLS 1.3.
- Enable Opportunistic Encryption.
- Enable TLS 1.3.
- Enable Automatic HTTPS Rewrites
- Set Authenticated Origin Pulls to On.
- Enable HTTP/2.
- Enable HTTP/3 (with QUIC). (Optional)
- Enable 0-RTT Connection Resumption. (Optional)
- Enable IPv6 Compatibility. (Optional)
- Enable gRPC. (Optional)
- Enable WebSockets. (Optional)
- Enable Onion Routing. (Optional)
- Set Pseudo IPv4 to Add Header. (Optional)
- Enable IP Geolocation. (Optional)
- In WordPress, go to Settings >> Nginx Helper
- Check Enable Purge.
- Select "nginx Fastcgi cache" for Caching Method
- Select "Using a GET request to PURGE/url (Default option)" for Purging Method.
- Check all of the boxes under Purging Conditions.
- Save Changes.
EngineScript will install the Cloudflare Super Page Cache plugin by default, as it super charges your domain's performance by utlizing the Cloudflare network. We still utilize Nginx FastCGI Cache where applicable as well. This plugin also has some added benefits that apply to EngineScript because it also works with the Nginx Helper plugin, Redis Object Cache, and PHP OpCache to clear out stale caches when the Cloudflare network's cache has been cleared. Use of this plugin is highly recommended for most applications. We've done all of the configuration work within Nginx to get things up and running quickly, but you'll need to follow the steps below before Cloudflare Super Page Cache is up and running.
- In WordPress, go to Settings >> Super Page Cache for Cloudflare.
- Retrieve your Cloudflare API key at https://dash.cloudflare.com/profile/api-tokens.
- Authentication mode: API Key.
- Cloudflare email: Your email.
- Cloudflare API Key: Your API Key.
- Log mode: Whatever you prefer.
- Cloudflare Domain Name: Your domain.
- Cloudflare Cache-Control max-age: 31536000
- Browser Cache-Control max-age: 60
- Automatically purge the Cloudflare's cache when something changes on the website: Purge cache for related pages only
- Don't cache the following dynamic contents: Check all boxes marked as recommended and then also check "Pages with query args" and "WP JSON endpoints"
- Don't cache the following static contents: Check all boxes marked as recommended
- Prevent the following URIs to be cached: Enter the folowing:
*add-to-cart* *add_to_cart* *ao_speedup_cachebuster* /*jetpack=comms* /*removed_item* /cart* /certificate* /checkout* /edd-* /feed* /my-account* /my-courses* /order/* /wc-ajax* /wc-api* /wp-json*
- Strip response cookies on pages that should be cached: No
- Automatically purge single post cache when a new comment is inserted into the database or when a comment is approved or deleted: Yes
- Automatically purge the cache when the upgrader process is complete: Yes
- Posts per page: 10 (or whatever you would prefer)
- Overwrite the cache-control header for Wordpress's pages using web server rules: Yes
- Force cache bypassing for backend with an additional Cloudflare page rule: Disabled
- Purge HTML pages only: No
- Disable cache purging using queue: No
- Worker mode: Disabled
- Enable fallback page cache: No
- Add browser caching rules for static assets: Yes
- Save
- Enable preloader: Yes
- Automatically preload the pages you have purged from Cloudflare cache with this plugin: Yes
- Preloader operation: Choose what content you want the preloader to grab. I do all menus and sidebars.
- Preload all URLs into the following sitemaps: Enter /sitemap.xml. This assumes you're using The SEO Framework plugin that we automatically installed for you. If you use a different SEO plugin, your sitemap filename may be different.
- Varnish Support: No
- Automatically purge the OPcache when Cloudflare cache is purged: Yes
- Automatically purge the object cache when Cloudflare cache is purged: Yes
Most of these are not used, so just scroll past the ones that say Inactive Plugin.
- Don't cache the following WooCommerce page types: Check all recommended boxes and anything else you want
- Automatically purge cache for product page and related categories when stock quantity changes: Yes
- Automatically purge cache for scheduled sales: Yes
- Automatically purge the cache when Nginx Helper flushs the cache: Yes
- SEO redirect Yes
- Remove Cache Buster Query Parameter: Yes
Follow this tutorial exactly: https://gist.github.com/isaumya/af10e4855ac83156cc210b7148135fa2. Things will not work correctly if you skip this part.
| Location | Usage | 
|---|---|
| /etc/mysql | MySQL (MariaDB) config | 
| /etc/nginx | Nginx config | 
| /etc/php | PHP config | 
| /etc/redis | Redis config | 
| /home/EngineScript | EngineScript user directories | 
| /usr/local/bin/enginescript | EngineScript source | 
| /var/lib/mysql | MySQL database | 
| /var/log | Server logs | 
| /var/www/admin/enginescript | Tools that may be accessed via your server's IP address | 
| /var/www/sites/yourdomain.com/html | Root directory for your WordPress installation | 
| Command | Function | 
|---|---|
| es.backup | Runs the backup script to backup all domains locally and optionally in the cloud | 
| es.cache | Clear FastCGI Cache, OpCache, and Redis (server-wide) | 
| es.config | Opens the configuration file in Nano | 
| es.images | Losslessly compress all images in the WordPress /uploads directory (server-wide) | 
| es.info | Displays server information | 
| es.install | Runs the main EngineScript installation script | 
| es.menu | EngineScript menu | 
| es.mysql | Displays your MySQL login credentials in the terminal | 
| es.permissions | Resets the permissions of all files in the WordPress directory (server-wide) | 
| es.restart | Restart Nginx and PHP | 
| es.server | Displays server information | 
| es.update | Update EngineScript | 
| es.variables | Opens the variable file in Nano. This file resets when EngineScript is updated | 
- MARIADB - https://mariadb.org/download/
- NGINX CACHE PURGE - https://github.com/nginx-modules/ngx_cache_purge
- NGINX HEADERS MORE - https://github.com/openresty/headers-more-nginx-module
- NGINX MAINLINE - https://nginx.org/en/download.html
- OPENSSL - https://www.openssl.org/source/
- PCRE2 - https://github.com/PCRE2Project/pcre2/releases
- PHP - https://launchpad.net/~ondrej/+archive/ubuntu/php
- PHPMYADMIN - https://www.phpmyadmin.net/downloads/
- PNGOUT - http://www.jonof.id.au/kenutils.html
- WORDFENCE CLI - https://github.com/wordfence/wordfence-cli/releases
- ZLIB-Cloudflare - https://github.com/cloudflare/zlib
- ZLIB - https://github.com/madler/zlib
Need a VPS? EngineScript recommends Digital Ocean