Skip to content

Latest commit

 

History

History
75 lines (50 loc) · 2.17 KB

README.md

File metadata and controls

75 lines (50 loc) · 2.17 KB

laravel-vm

A recipe for building a development VM for working on Laravel and apps.

  • PHP 5.5
  • MySQL
  • PostgreSQL
  • Redis (w/web frontend)
  • Memcached
  • SQLite
  • Beanstalkd (w/web frontend)

Setup (host)

Ansible

Vagrant uses Ansible on your host machine to provison, but installs it on the guest machine if your host is running Windows. For Linux, OS X, others:

sudo pip install ansible

Virtualbox plugins (optional)

I strongly recommend using this Vagrant plugin that makes sure your VirtualBox guest additions are up-to-date. If you have issues when bringing your VM down and back up again this can help.

Setup (VM)

To add your app to the virtual machine, open Vagrantfile and edit line 8 ("Add your Laravel app here") with the relative path to your app on your local (host) machine. For example, I submodule this repository into my applications and then reference one level above:

git submodule add https://github.com/rmasters/laravel-ansible vm

# Add your Laravel app here
#config.vm.synced_folder "../", "/srv/app"

To boot your VM:

vagrant up

# If provisioning doesn't happen, run
vagrant provision

# You should see [default] Running provisioner: ansible...

Usage

The following ports are exposed:

You can change these ports in your Vagrantfile. Vagrant may reassign them if they are already in use.

Connect to the following services in your app or by using clients on your host by tunnelling through SSH (run vagrant ssh-config to find which local port):

  • MySQL - 127.0.0.1:3306
  • PostgreSQL - 127.0.0.1:5432
  • Redis - 127.0.0.1:6379

To tunnel through SSH use the username vagrant and the SSH key in ~/.vagrant.d/insecure_private_key.

MIT licensed.