This file describes how to use Vagrant (http://www.vagrantup.com) to
create a devstack virtual environment that contains two nova instances
running a simple web server and a working Neutron LBaaS Version 2 load
balancer backed by Octavia.

1) Install vagrant on your host machine.  Vagrant is available for
Windows, Mac OS, and most Linux distributions.  Download and install
the package appropriate for your system.  On Ubuntu, simply type:

    sudo apt-get install vagrant

2) copy 'Vagrantfile' from this directory to any appropriate directory

    mkdir $HOME/lbaas-octavia-vagrant            # or any other appropriate directory
    cp -rfp $HOME/lbaas-octavia-vagrant

3) Continue either by the single node deployment (6GB RAM minimum), or by the
multinode deployment (12GB RAM minimum).

Single node deployment
~~~~~~~~~~~~~~~~~~~~~~

1) Create and deploy the environment VM

    cd $HOME/lbaas-octavia-vagrant/single
    vagrant up

    Alternatively, you can specify the number of vcpus or memory:
    VM_CPUS=4 VM_MEMORY=8192 vagrant up

2) Wait for the vagrant VM to boot and install, typically 20-30 minutes

3) SSH into the vagrant box

    vagrant ssh

4) Continue on the common section below

Multinode
~~~~~~~~~

This will create an environment where the octavia services are replicated
across two nodes, and in front of the octavia api, an haproxy is configured
to distribute traffic among both API servers, and provide failure tolerance.

Please note that the database is a single mysql instance, with no clustering.

1) Create and deploy the environment VMs

   cd $HOME/lbaas-octavia-vagrant/multinode
   vagrant up main

2) Wait for the main node to be deployed, and then start the second node

   vagrant up second

3) Log in to the main node, and run local-manual.sh now that everything is
   deployed

   vagrant ssh main
   cd devstack
   ./local-manual.sh
   logout

4) SSH in any of the vagrant boxes:

   vagrant ssh main
   vagrant ssh second

4) Continue on the common section bellow

Common to multinode and single node
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

1) Determine the loadbalancer IP:

    source openrc admin admin
    openstack loadbalancer show lb1 -f value -c vip_address

2) make HTTP requests to test your load balancer:

        curl <LB_IP>

where <LB_IP> is the VIP address for lb1.  The subsequent invocations of
"curl <LB_IP>" should demonstrate that the load balancer is alternating
between two member nodes.