2015-03-25 14:12:24 -07:00
|
|
|
This file describes how to use Vagrant (http://www.vagrantup.com) to
|
2016-06-02 16:08:23 -04:00
|
|
|
create a devstack virtual environment that contains two nova instances
|
2015-03-25 14:12:24 -07:00
|
|
|
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
|
2016-06-02 16:08:23 -04:00
|
|
|
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
|
2015-03-25 14:12:24 -07:00
|
|
|
vagrant up
|
|
|
|
|
2016-05-23 07:39:18 -04:00
|
|
|
Alternatively, you can specify the number of vcpus or memory:
|
|
|
|
VM_CPUS=4 VM_MEMORY=8192 vagrant up
|
|
|
|
|
2016-06-02 16:08:23 -04:00
|
|
|
2) Wait for the vagrant VM to boot and install, typically 20-30 minutes
|
2015-03-25 14:12:24 -07:00
|
|
|
|
2016-06-02 16:08:23 -04:00
|
|
|
3) SSH into the vagrant box
|
2015-03-25 14:12:24 -07:00
|
|
|
|
|
|
|
vagrant ssh
|
|
|
|
|
2017-03-14 17:39:45 +08:00
|
|
|
4) Continue on the common section below
|
2016-06-02 16:08:23 -04:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2017-03-14 17:39:45 +08:00
|
|
|
Please note that the database is a single mysql instance, with no clustering.
|
2016-06-02 16:08:23 -04:00
|
|
|
|
|
|
|
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:
|
2015-03-25 14:12:24 -07:00
|
|
|
|
|
|
|
source openrc admin admin
|
2018-09-17 16:58:08 +08:00
|
|
|
openstack loadbalancer show lb1 -f value -c vip_address
|
2015-03-25 14:12:24 -07:00
|
|
|
|
2016-06-02 16:08:23 -04:00
|
|
|
2) make HTTP requests to test your load balancer:
|
2015-03-25 14:12:24 -07:00
|
|
|
|
|
|
|
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.
|