Skip to content

Latest commit

 

History

History
259 lines (157 loc) · 15.2 KB

README.md

File metadata and controls

259 lines (157 loc) · 15.2 KB

#From the Ground Up: Learning Vagrant for WordPress on Mac OS X

Written 2016-01-01 by @mikeschinkel

Consensus among the more advanced WordPress developers is that currently Vagrant is the preferred choice for setting up a local web server for WordPress development. Better than MAMP, WAMP, ServerPress or anything else that is similar.

Note: This tutorial will be most helpful if you are running a Mac on OS X. Those on Linux may also find it similarly helpful but I have made no attempt to address Vagrant running on Windows so chances are good the tutorials will not all work for you. Caveat Emptor!

##What is Vagrant?

Vagrant is a tool that does lot of things and has a lot of uses. But let us limit to what is relevant for local WordPress development:

Vagrant is a software tool for loading and managing Virtual Machines on your development computer by controlling a Provider such as Oracle's VirtualBox or VMWare Fusion. The virtual machine will run a Linux-based web & database server such as Apache or Nginx & MySQL or Maria to server your web projects from WordPress's source files stored on a local directory of your development computer.

In addition Vagrant Provisions your virtual machine by running whatever scripts and/or tools needed to install and configure server software -- tools like Puppet and Chef -- and Vagrant can also run Composer to download and configure your source code to make your virtual machine ready for your development.

###Key Basics about Vagrant

  • Vagrant is Open-Source,
  • Vagrant is a Command-Line Tool, and
  • Vagrant's actions are Configured via a File named Vagrantfile.

##"Easy" Options for Vagrant + WordPress There are many "easy" options to get started using Vagrant with WordPress. They include:

Except the problem with using these when you are new to Vagrant is you will mostly likely get stuck without the skills to troubleshoot just as an algebra student could not begin to pass an advanced calculus test. And you really don't want to be stuck up a creek without a paddle when you are on a deadline.

###Better to Learn Vagrant from the Ground Up Once you'd learn the fundamentals of Vagrant then is makes sense to revisit potentially using these "easy" solutions. And once you start to get proficient with Vagrant you can study the Vagrantfile for any of the above options to learn how to handle more advanced configurations.

When you do become proficient with Vagrant and whichever provisioner you choose then some of the pre-built easy options might be a great choice. However by then you'll probably want the control of building the exact box you need anyway.

##Prerequisites

There are several things you need to have installed and/or have experience with before even trying to work with Vagrant. They include:

##Installing Vagrant There is an easy way and a slightly less easy way to install Vagrant on Mac OS X.

Choose your poison:

  1. The easy way to install Vagrant is using HomeBrew with Caskroom:

     $ brew cask install vagrant
    
  2. The slightly less easy way is to download the Vagrant installer, mount the disk image (.DMG) file, and then run the Vagrant.pkg installer.

##Choosing a Box

Vagrant needs to start with a bootable disk image of your desired operating system which Vagrant vernacular is called a "Box". You could build your own Box if you wanted but there are literally hundreds available free for the taking, erm, the downloading. You can search or browse for boxes here.

One of the most downloaded boxed is hashicorp/precise32 probably because it is used for the example on the Vagrant home page.

Another box to consider is scotch/box which is a box with a simple LAMP stack installed.

Finally, consider wplib/wplib-box which provides everything you need for local development using the WPLib Professional Development Platform for WordPress.

##Initializing your First Vagrantfile Let us pick the Precise32 Box because it is the least likely to cause headaches when just getting started.

Create a directory ~/Sites/vagrant-wp and then initialize Vagrant there:

$ mkdir ~/Sites/vagrant-wp
$ cd ~/Sites/vagrant-wp
$ vagrant init hashicorp/precise32

That last command generates the following Vagrantfile (I removed comments that are generated to reveal just the actual commands. You'll note the Vagrant syntax is the Ruby language):

Vagrant.configure(2) do |config|
    config.vm.box = "hashicorp/precise32"
end

If you are curious to see the full Vagrantfile complete with generated comments you can cat its contents to the terminal window:

$ cat Vagrantfile | more

##Running your First Box via Vagrant This step is simple. Just run:

$ vagrant up

This will take at least a few minutes. It will first check to see if you have the Precise32 Box downloading and if not it will download for you.

###If It Does Not Work? Vagrant isn't magic and sometimes it does not work. If you run into problems at any time, just to Troubleshooting Vagrant for potential help.

###Where are Local Vagrant Boxes Stored? When Vagrant downloads a box it places it in the ~/.vagrant.d/boxes folder on Mac OS X. Why not open another Terminal window while vagrant up runs and check it out?:

$ ls -l ~/.vagrant.d/boxes/

When you run that command you will probably get output something like this:

drwxr-xr-x+ 4 mikeschinkel  staff  136 Jan  1 07:33 hashicorp-VAGRANTSLASH-precise32

###Downloading a Vagrant Box Directly (OPTIONAL) While on the subject of boxes, Vagrant has the box add command that allows you to just download a Box and place into your Box store at ~/.vagrant.d/boxes for later use.

Let's downloading the Scotch Box directly in your other Terminal window:

$ vagrant box add scotch/box

After downloading if you run ls -l ~/.vagrant.d/boxes/ you should see something like:

drwxr-xr-x+ 4 mikeschinkel  staff  136 Jan  1 07:33 hashicorp-VAGRANTSLASH-precise32
drwxr-xr-x+ 4 mikeschinkel  staff  136 Jan  2 02:51 scotch-VAGRANTSLASH-box

##Access Your Vagrant Box's Command Line Once your Vagrant Box is up and running you can connect directly to is and access it's command line using SSH:

$ vagrant ssh

Go ahead, look around in your new Vagrant box. Do an ls on the special /vagrant directory:

(box) $ ls /vagrant

Vagrant Mirrors Files Between Virtual Box and Local Computer

The /vagrant directory inside your virtual box is a mirror of your local computer's ~/Sites/vagrant-wp directory where you have created the Vagrantfile. THIS is the key magic that makes Vagrant so great for web development; it lets you edit your files locally yet serve them to your browser via your virtual box!

Let's use echo to create an index.html file, still from within your virtual box:

(box) $ echo Hello World! > /vagrant/index.html

Now type exit to exit the virtual box and Shazam! you will find your new index.html in the same folder as your Vagrantfile on your local computer.

Installing a Web Server

We'll install Apache because it's the most widely known. This requires us to run a provisioning script. Add the following to your VagrantFile just after the config.vm.box assignment:

config.vm.provision :shell, path: "provision.sh"

That command tells Vagrant to run a provisioning script on the virtual machine when you run vagrant up for the first time, or vagrant reload --provision after your first vagrant up.

###The Provisioning Script

Create provision.sh in the same folder as your Vagrantfile. It should contain the following Bash shell script commands:

#!/usr/bin/env bash
echo Installing Apache...
apt-get update
apt-get install -y apache2
if ! [ -L /var/www ]; then
  rm -rf /var/www
  ln -fs /vagrant /var/www
fi
echo Apache Installed.

Explaining the script is a bit out of scope for now. If you'd like to learn more you can find details here:

###Reload and (Re-)Provision Since we've made configuration changes we need to reload with the (re-)provision switch:

$ vagrant reload --provision

This will take a bit of time like the original vagrant up did.

###Confirming Apache is Installed Now we can test to see if Apache is installed with apachectl:

$ vagrant ssh
(box) $ apachectl -V

Apachectl should spit out a bunch of configuration lines if it is installed.

Then we can actually verify that Apache is serving web pages by running wget on our localhost (that switch is "dash-uppercase-oh" followed by "space-dash-space"):

(box) wget -O - http://127.0.0.1

It all installed correctly then your wget call will have outputted your earlier echoed Hello World! content.

##Giving your Box an IP Address You now have a web server on your box but no way to reach it from outside the box; we need to provide an IP address. Add the following right after your config.vm.provision command (we chose 99.99.99.99 because it is easy to remember!):

config.vm.network "private_network", ip: "99.99.99.99"

Then reload and re-provision:

$ vagrant reload --provision

Now you should be able to make requests of your virtual box's Apache server from your local computer. Try this (that switch is "dash-zero"):

$ curl -0 http://99.99.99.99/

If curl output Hello World! you have success! Next try http://99.99.99.99/ in your favorite browser and you should get the same result.

##The End (Currently) If you've made it this far then you have finished what we have written thus far in our guide. We hope it helped.

##%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

##Troubleshooting Vagrant Sometimes Vagrant can be infuriating. It's often hard to debug a problem, but here are some of the problems we've run into and the solutions we discovered:

###Breaking out of a Running Vagrant Script

For example, you might get the following output repeatedly:

default: Warning: Remote connection disconnect. Retrying...

The first thing to try is to wait to see if your system is just responding slowly.

But if you are tired of waiting you can press Ctrl-Z (no, not Cmd-Z) to break out of the loop. You may need to press it a few times to break out completely and get a command prompt back.

Once you break out you may need to kill Ruby since it is likely still running. You can run Activity Monitor

###Turn on the GUI Sometimes your "headless" box will be waiting for a user to do something and with the GUI turned off you'll never know. The following will turn on the GUI so you can see if your box is waiting for any kind of input.

Uncomment the following lines in your Vagrantfile generated by vagrant init, or add them if you are writing the file from scratch:

config.vm.provider "virtualbox" do |vb|
   vb.gui = true
end

If you are writing your Vagrantfile from scratch be sure to include them inside the following control structure:

Vagrant.configure(2) do |config| 
    config.vm.box = scotch/box"
    config.vm.provider "virtualbox" do |vb|
        vb.gui = true
    end
end 

Now run vagrant up again and see if that reveals an issue you can resolve.

###When the GUI Captures your Mouse If you are looking at the VirtualBox window and you seem to loose your mouse cursor, VirtualBox will "release" it when your press Left-Cmd (or it may be another key; look at the bottom right corner of the "window chrome" for your VirtualBox window.

###Google is your Friend And if none of the above helps then Google may be your friend here.

If you get an error message google it along with "Vagrant" and removing anything that's unique to your machine in the error message such as directory names.