Skip to content

A Vagrant stack designed for Laravel 4 development and deployment

Notifications You must be signed in to change notification settings

drafie/Vagrant-Laravel-Stack

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Vagrant Laravel Stack

Just dump the Vagrantfile and Berksfile in your Laravel project and you're good to go!

Description

A Vagrant stack designed for Laravel 4 development and deployment.

Chef is used for provisioning and Berkshelf is used to manage cookbooks.

Authors note: I've been wanting to do a Laravel-specific Vagrant stack for a while, and when Taylor Otwell tweeted out that he was looking for such a thing, I decided to build it out based on his requirements.

Requirements

Installation

First, install Laravel 4 in to a local directory on your machine.

$ composer create-project laravel/laravel projectname --prefer-dist

All you need to do now, in order to run your Laravel installation using Vagrant is to place the Vagrantfile and Berksfile from this repository in the root of your Laravel installation

$ cd projectname
$ curl -O https://raw.github.com/MiniCodeMonkey/Vagrant-Laravel-Stack/master/\{Vagrantfile,Berksfile\}

Optionally, you can configure the Vagrantfile to specify the project name or customize the installed packages or modules.

$ vim Vagrantfile

Your directory structure should look something like this:

├── CONTRIBUTING.md
├── Berksfile - Your new Berksfile
├── Dirtfile.json
├── README.md
├── Vagrantfile - Your new Vagrantfile
├── app
   ├── commands
   ├── config
   ├── controllers
   ├── database
   ├── lang
   ├── models
   ├── start
   ├── storage
   ├── tests
   ├── views
├── artisan
├── bootstrap
├── composer.json
├── public
├── server.php

You can now start the Virtual Machine and initialize the provisioning process.

$ vagrant up

The first run may take 8-10 minutes to complete, so you might want to go grab a cup of coffee at this point.

After the provisioning has completed, you can access your project at http://projectname.local

Configuration

The stack is designed in such a way that it is very easy to configure. Just update the Vagrantfile to change installed npm packages, apt packages, php modules, etc.

Installed software

  • Ubuntu Precise base box (Should work with other operating systems with few or no changes)
  • Apache 2.4
  • MySQL
  • PostgreSQL
  • PHP 5.5 (with apcu, mysql, curl, mcrypt, memcached, gd)
  • memcached
  • Redis
  • Beanstalkd
  • Beanstalk Console
  • Postfix
  • XDebug
  • Grunt
  • composer
  • curl
  • vim, git, screen
  • phpunit

Default credentials

MySQL

  • Username: root
  • Password: laravel
  • Port: 3306

PostgreSQL

  • Username: root
  • Password: laravel
  • Port: 5432

Note: Remote database access is enabled by default, so you can access the MySQL or PostgreSQL database using your favorite client with the above credentials (and using e.g. projectname.local as hostname).

Redis

  • Port: 6379

Beanstalkd

  • Port: 11300

Beanstalk Console can be accessed on the /beanstalk alias, e.g. http://projectname.local/beanstalk

Memcached

  • Port: 11211

Bitdeli Badge

About

A Vagrant stack designed for Laravel 4 development and deployment

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published