Skip to content
This repository has been archived by the owner on May 3, 2018. It is now read-only.

[DISCONTINUED] Vagrant Multi Machine LAMP Stack for PHP development. See https://github.com/gmdotnet/vagrant-multi-machine-virtualbox

License

Notifications You must be signed in to change notification settings

giuseppemorelli/Vagrant-LAMP

Repository files navigation

[DISCONTINUED] See new project here: https://github.com/gmdotnet/vagrant-multi-machine-virtualbox

Vagrant Box LAMP Stack

This is a DEV LAMP vagrant box and configuration. Use it for a basic PHP development.

Features

  • vagrant multi machine: use for separate web, db and session machine
  • choose your favourite box, or get pre-configured box (see BOXES.md)
  • ansible playbook for your configuration
  • YAML config file. No more Vagrantfile to edit!
  • with vagrant plugin HostsUpdater: no more /etc/hosts file to edit!

Requirements

  • virtualbox 5.x
  • vagrant >1.8.4
  • (optional)vagrant HostsUpdater plugin: https://github.com/cogitatio/vagrant-hostsupdater install with vagrant plugin install vagrant-hostsupdater
  • (in case of error of shared folder mount errors) vagrant vagrant-vbguest plugin (install with the command vagrant plugin install vagrant-vbguest)

How to use

Provision

  • enable/disable your provision script directory in your config.yaml file
  • see the section below for more info

Vagrant boxes created

You can choose any box you want. This is a pre-configured LAMP stack. See BOXES.md for software installed list.

  • giuseppemorelli/lamp-stack 1.0.1 (debian jessie 8.5)
  • giuseppemorelli/lamp-stack 1.0.2 (debian jessie 8.6)
  • giuseppemorelli/lamp-stack 1.0.3 (debian jessie 8.6)

MySQL server

  • created an user called local (password local) with root privilegies
  • root password is vagrant

Apache server

  • ServerName is vagrant
  • daemon user is vagrant
  • root folder is /var/www
  • mod_rewrite and mod_vhost_alias enabled
  • IMPORTANT: you need to add EnableSendfile Off on your website configuration under <Directory "..."> ( here all info https://www.vagrantup.com/docs/synced-folders/virtualbox.html )
  • All website must be *.vagrant because main server name is vagrant, if you want to change please edit /etc/apache2/ports.conf

PHP Xdebug

  • auto-activated in PHP cli and PHP "web"
  • IDEKEY = "VAGRANT"
  • uncomment xdebug.remote_host in php.ini to enable your IDE for remote xdebug

SMTP and EMAIL with postfix and MailHog

  • postfix is configured as satellite system with 127.0.0.1:1025
  • mailhog do not start automatically. Just open a shell and type mailhog
    • web interface is set on <vagrant ip>:8025
  • all emails are not sent outside the machine
  • to test:
    • start mailhog
    • send a test email with echo "this is a test email | mail -s "subject test email" fake@fake.mail
    • check on your browser <vagrant ip>:8025 the email sent
  • you can use mailhog as SMTP server, just configure your application to send email at 127.0.0.1 with port 1025

Vagrant Provision script

  • backup_database.sh: you can use this script as single shell script or enable it in config.yaml

Vagrant Provision Ansible Local

There is a sample ansible playbook to enable service and configuration for your machine.

Instructions:

  • rename ansible/playbook.yml.sample in ansible/playbook.yml
  • edit your config.yaml to enable ansible provision
provision:
    ansible: yes
  • start vagrant provision (automatically with new vagrant machine, with vagrant provision for vagrant machine previously created)

If you aren't familiar with ansible you can install Webmin panel. Just follow the instruction below.

Install Webmin panel

From vagrant shell:

sudo su
wget http://www.webmin.com/jcameron-key.asc
apt-key add jcameron-key.asc
rm jcameron-key.asc
echo "deb http://download.webmin.com/download/repository sarge contrib" > /etc/apt/sources.list.d/webmin.list
apt-get update
apt-get install -y apt-transport-https
apt-get install -y webmin

Login to https://<ip vagrant or alias>:10000 with user root and password vagrant

Other info

  • root password is vagrant but you can simply run sudo su from vagrant user
  • if you can't find a configuration in this file before, it means is used the default value

Contribution

Any contribution is highly appreciated. The best way to contribute code is to open a pull request on GitHub.
Please create your pull request against the develop branch

Credits

Giuseppe Morelli - giuseppemorelli.net