An easy to use, fast to spin up WordPress Vagrant environment modeled after managed WordPress hosting platforms like WP Engine and Flywheel.
From a "cold boot" your WordPress Vagrant environment should be ready to go in about a minute, if not faster. Other WordPress Vagrant projects take much, much longer.
Vagrant and VirtualBox must be installed. The vagrant-hostmanager plugin is highly recommended, but not required.
Complete first-time setup instructions are below.
- Download the zip archive or clone this repo
- Unzip and rename the directory to something like
yoursite.test
- For existing projects, clone or copy your site into a
site
directory. New projects will createsite
. - Optionally copy a MySQL dumpfile into the project directory
- Install plugins:
vagrant plugin install vagrant-hostmanager
(Mac and Linux users should also install thevagrant-bindfs
plugin) - Run
vagrant up
When the Vagrant environment is provisioned a fresh install of WordPress will be applied to the site
directory. Any changes to core files or default themes will be lost. Those files should really never be changed anyway, and this behavior is deliberate and intentional.
To avoid being asked for a password on every vagrant up
(when using the vagrant-hostmanager plugin), edit the sudoers file and add the lines from this gist.
- Download the zip archive or clone this repo
- Unzip and rename the directory to
yoursite.dev
- Download a backup snapshot from your WP Engine Dashboard.
- Decompress the zip archive and rename the resulting directory to
site
- Copy
site
intoyoursite.dev
, replacing the existingsite
directory. - Run
vagrant up
- Download the zip archive or clone this repo
- Unzip and rename the directory to
yoursite.dev
- Download a backup snapshot from your Flywheel Dashboard. Flywheel backup archives contains a
backup.sql
database dumpfile and afiles
directory. - Rename
files
tosite
- Copy
site
andbackup.sql
intoyoursite.dev
, replacing the existingsite
directory. - Run
vagrant up
While this project's main goal is to provide a fast, standard WordPress development environment based on popular managed hosts, there are times where that just won't work. For sites installed in a subdirectory or using other custom file structure, there are options to help stage those as well.
The config.yml
file includes wp_dir
and wp_content
settings which can be used to override the WordPress defaults.
Below are the complete steps necessary to use the Basic WordPress Vagrant Environment on a new Mac. These steps should only need to be done once, but it's useful to review if something isn't working correctly.
- Download the Vagrant installer from vagrantup.com and install Vagrant.
- Download the VirtualBox installer from virtualbox.org and install VirtualBox.
That's everything, now just follow the Instructions to spin up your WordPress environment.
One of this project's goals is to promote disposability: Developers should be able to spin up and tear down local development sites quickly and dependably. An ideal managed WordPress site is just a database dumpfile and whatever code exists in the wp-content
directory. Everything outside of that should be replaceable. The only exception would be site-specific configurations in config.yml
.
Many custom options can be set in config.yml
:
-
wp_download
can be used to install specific WordPress versions. -
install_plugins
toggles automatic installation of missing plugins -
wp_dir
changes the install location of WordPress, use this to install WordPress into a subdirectory. -
wp_content
remaps thewp-content
directory. Useful for working on roots.io style installations. -
enable_xdebug
toggles xDebug display -
table_prefix
maps directly to the WordPress Database Table prefix inwp-config.php
-
Missing WordPress plugins will be installed if they can be found in the WordPress Plugin Directory.
-
All settings for Debugging in WordPress are enabled.
-
Save
vagrant-hostmanager-nopasswd
to/etc/sudoers.d/
for password-free, host-managedvagrant up
. -
File permissions are handled by managed hosts and may differ between projects. To ignore permissions for sites managed with Git, run this in your local repo:
git config core.filemode false
Log directly into /wp-admin
and try to activate your theme again.
The Hostmanager and Bind-fs plugins will be auto-installed on vagrant up
.
An extensive .gitignore file will be added to the site directory if one doesn't already exist. This file excludes all WordPress core files from Git.
The Ansible provisioner will search for MySQL database dumpfiles in the top five levels of the project, ignoring WordPress core and common vendor directories. The top-most (first-found) database dumpfile will be imported.
A default theme can be set in config.yml
. If no default is set, the Ansible provisioner will attempt to activate a theme whose name matches the name
attribute in site/package.json
. These settings help prevent white-screens when restoring a project which uses versioned theme directories.
Using Composer from vagrant ssh
may require a GitHub OAuth token. More info: API rate limit and OAuth tokens.
For direct MySQL access, vagrant ssh
, then mysql wordpress
.
The base box was generated from the ideasonpurpose/basic-wordpress-box project.
Some solutions for Chrome's annoying HSTS lockout. Try typing badidea
on the error page.
Vagrant Hostmanager may silently fail to write to etc/hosts
on Windows 10.
Microsoft Edge on Windows 10 will not load websites from local IP addresses. IE11, Chrome and Firefox all work correctly.
This project is sponsored by and used in production at Ideas On Purpose.