From 369f68832e54ad6a7e12823dc2490fd777b0cb4e Mon Sep 17 00:00:00 2001 From: Kevin Carter Date: Tue, 1 Aug 2017 09:13:15 -0500 Subject: [PATCH] Add environment options and re-flow the README.rst Change-Id: I7a2640856045e36043de8508f9421fbd8a593591 Signed-off-by: Kevin Carter --- multi-node-aio/README.rst | 84 ++++++++++++++---------- multi-node-aio/playbooks/deploy-dhcp.yml | 2 + multi-node-aio/playbooks/deploy-osa.yml | 2 + multi-node-aio/playbooks/deploy-pxe.yml | 2 + multi-node-aio/playbooks/deploy-vms.yml | 12 ++++ multi-node-aio/playbooks/setup-host.yml | 2 + 6 files changed, 69 insertions(+), 35 deletions(-) diff --git a/multi-node-aio/README.rst b/multi-node-aio/README.rst index 175eed1c..14dc37b9 100644 --- a/multi-node-aio/README.rst +++ b/multi-node-aio/README.rst @@ -19,17 +19,17 @@ and 1 load balancer all using a Hyper Converged environment. Process ------- -Create at least one physical host that has public network access and is running the -Ubuntu 14/6.04 LTS Operating system. System assumes that you have an unpartitioned -device with at least 1TB of storage, however you can customize the size of each VM -volume by setting the option ``${VM_DISK_SIZE}``. If you're using the Rackspace -OnMetal servers the drive partitioning will be done for you by detecting the largest -unpartitioned device. If you're doing the deployment on something other than a Rackspace -OnMetal server you may need to set the ``${DATA_DISK_DEVICE}`` variable accordingly. -the playbooks will look for a volume group named "vg01", if this volume group exists -no partitioning or setup on the data disk will take place. To effectively use this -process for testing it's recommended that the host machine have at least 32GiB of -RAM. +Create at least one physical host that has public network access and is running +the Ubuntu 14/6.04 LTS Operating system. System assumes that you have an +unpartitioned device with at least 1TB of storage, however you can customize the +size of each VM volume by setting the option ``${VM_DISK_SIZE}``. If you're +using the Rackspace OnMetal servers the drive partitioning will be done for you +by detecting the largest unpartitioned device. If you're doing the deployment on +something other than a Rackspace OnMetal server you may need to set the +``${DATA_DISK_DEVICE}`` variable accordingly. the playbooks will look for a +volume group named "vg01", if this volume group exists no partitioning or setup +on the data disk will take place. To effectively use this process for testing +it's recommended that the host machine have at least 32GiB of RAM. =========== ======== ============ Physical Host Specs known to work well @@ -41,27 +41,30 @@ Physical Host Specs known to work well These specs are covered by the Rackspace OnMetal-IO v1/2 Servers. -When your ready, run the build script by executing ``bash ./build.sh``. The build script -current executes a deployment of OpenStack Ansible using the master branch. If you want to -do something other than deploy master you can set the ``${OSA_BRANCH}`` variable to any -branch, tag, or SHA. +When your ready, run the build script by executing ``bash ./build.sh``. The +build script current executes a deployment of OpenStack Ansible using the master +branch. If you want to do something other than deploy master you can set the +``${OSA_BRANCH}`` variable to any branch, tag, or SHA. Post Deployment --------------- -Once deployed you can use virt-manager to manage the KVM instances on the host, similar to a DRAC or ILO. +Once deployed you can use virt-manager to manage the KVM instances on the host, +similar to a DRAC or ILO. LINUX: - If you're running a linux system as your workstation simply install virt-manager - from your package manager and connect to the host via QEMU/KVM:SSH + If you're running a linux system as your workstation simply install + virt-manager from your package manager and connect to the host via + QEMU/KVM:SSH OSX: - If you're running a MAC you can get virt-manager via X11 forwarding to the host - or install it via BREW. http://stackoverflow.com/questions/3921814/is-there-a-virt-manager-alternative-for-mac-os-x + If you're running a MAC you can get virt-manager via X11 forwarding to the + host or install it via BREW. http://stackoverflow.com/questions/3921814/is-there-a-virt-manager-alternative-for-mac-os-x WINDOWS: - If you're running Windows, you can install virt-viewer from the KVM Download site. + If you're running Windows, you can install virt-viewer from the KVM Download + site. https://virt-manager.org/download/ @@ -84,8 +87,9 @@ Console Access :alt: Screen shot of virt-manager console :align: center -The root password for all VMs is "**secrete**". This password is being set within the pre-seed files under the -"Users and Password" section. If you want to change this password please edit the pre-seed files. +The root password for all VMs is "**secrete**". This password is being set +within the pre-seed files under the "Users and Password" section. If you want +to change this password please edit the pre-seed files. ``build.sh`` Options @@ -124,15 +128,17 @@ Instruct the system to deploy OpenStack Ansible: Instruct the system to pre-config the envs for running OSA playbooks: ``PRE_CONFIG_OSA=${PRE_CONFIG_OSA:-true}`` -Instruct the system to run the OSA playbooks, if you want to deploy other OSA powered cloud, you can set it to false: +Instruct the system to run the OSA playbooks, if you want to deploy other OSA +powered cloud, you can set it to false: ``RUN_OSA=${RUN_OSA:-true}`` Re-kicking VM(s) ---------------- -Re-kicking a VM is as simple as stopping a VM, delete the logical volume, create a new logical volume, start the VM. -The VM will come back online, pxe boot, and install the base OS. +Re-kicking a VM is as simple as stopping a VM, delete the logical volume, create +a new logical volume, start the VM. The VM will come back online, pxe boot, and +install the base OS. .. code-block:: bash @@ -142,7 +148,8 @@ The VM will come back online, pxe boot, and install the base OS. virsh start "${VM_NAME}" -To rekick all VMs, the following command can be used on the host machine to cycle through all found VMs and re-provision them. +To rekick all VMs, the following command can be used on the host machine to +cycle through all found VMs and re-provision them. .. code-block:: bash @@ -157,14 +164,18 @@ To rekick all VMs, the following command can be used on the host machine to cycl Rerunning the build script -------------------------- -The build script can be rerun at any time. If you have a successful run before and simply want to re-kick everything I -recommend nuking VMs and then executing the build script. +The build script can be rerun at any time. If you have a successful run before +and simply want to re-kick everything I recommend nuking VMs and then executing +the build script. Deploying OpenStack into the environment ---------------------------------------- -While the build script will deploy OpenStack, you can choose to run this manually. To run a basic deploy using a given branch you can use the following snippet. Set the ansible option ``osa_branch`` or export the environment variable ``OSA_BRANCH`` when using the build.sh script. +While the build script will deploy OpenStack, you can choose to run this +manually. To run a basic deploy using a given branch you can use the following +snippet. Set the ansible option ``osa_branch`` or export the environment +variable ``OSA_BRANCH`` when using the build.sh script. .. code-block:: bash @@ -174,8 +185,9 @@ While the build script will deploy OpenStack, you can choose to run this manuall Snapshotting an environment before major testing ------------------------------------------------ -Running a snapshot on all of the vms before doing major testing is wise as it'll give you a restore point without having to re-kick -the cloud. You can do this using some basic ``virsh`` commands and a little bash. +Running a snapshot on all of the vms before doing major testing is wise as it'll +give you a restore point without having to re-kick the cloud. You can do this +using some basic ``virsh`` commands and a little bash. .. code-block:: bash @@ -184,9 +196,11 @@ the cloud. You can do this using some basic ``virsh`` commands and a little bash done -Once the previous command is complete you'll have a collection of snapshots within all of your infrastructure hosts. These snapshots -can be used to restore state to a previous point if needed. To restore the infrastructure hosts to a previous point, -using your snapshots, you can execute a simple ``virsh`` command or the following bash loop to restore everything to a known point. +Once the previous command is complete you'll have a collection of snapshots +within all of your infrastructure hosts. These snapshots can be used to restore +state to a previous point if needed. To restore the infrastructure hosts to a +previous point, using your snapshots, you can execute a simple ``virsh`` +command or the following bash loop to restore everything to a known point. .. code-block:: bash diff --git a/multi-node-aio/playbooks/deploy-dhcp.yml b/multi-node-aio/playbooks/deploy-dhcp.yml index a3dea2a8..18d886e2 100644 --- a/multi-node-aio/playbooks/deploy-dhcp.yml +++ b/multi-node-aio/playbooks/deploy-dhcp.yml @@ -59,6 +59,8 @@ group: root notify: restart dhcpd + environment: "{{ deployment_environment_variables | default({}) }}" + handlers: - name: restart dhcpd service: diff --git a/multi-node-aio/playbooks/deploy-osa.yml b/multi-node-aio/playbooks/deploy-osa.yml index 1f40ae6e..d2a8450c 100644 --- a/multi-node-aio/playbooks/deploy-osa.yml +++ b/multi-node-aio/playbooks/deploy-osa.yml @@ -130,5 +130,7 @@ when: - run_osa | default(true) | bool + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-osa diff --git a/multi-node-aio/playbooks/deploy-pxe.yml b/multi-node-aio/playbooks/deploy-pxe.yml index 06a95ec3..95e282cd 100644 --- a/multi-node-aio/playbooks/deploy-pxe.yml +++ b/multi-node-aio/playbooks/deploy-pxe.yml @@ -282,6 +282,8 @@ register: fstab with_dict: "{{ images }}" + environment: "{{ deployment_environment_variables | default({}) }}" + handlers: - name: restart nginx service: diff --git a/multi-node-aio/playbooks/deploy-vms.yml b/multi-node-aio/playbooks/deploy-vms.yml index 8c3c1c52..50dee597 100644 --- a/multi-node-aio/playbooks/deploy-vms.yml +++ b/multi-node-aio/playbooks/deploy-vms.yml @@ -70,6 +70,8 @@ - hostvars[item]['server_vm'] | default(false) | bool with_items: "{{ groups['pxe_servers'] }}" + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms @@ -86,6 +88,8 @@ - hostvars[item]['server_vm'] | default(false) | bool with_items: "{{ groups['pxe_servers'] }}" + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms @@ -116,6 +120,8 @@ - src: /root/.ssh/id_rsa.pub dest: /root/.ssh/id_rsa.pub + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms @@ -141,6 +147,8 @@ force: true state: absent + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms @@ -161,6 +169,8 @@ vg: cinder-volumes pvs: "/dev/vg00/cinder-volumes00" + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms @@ -211,5 +221,7 @@ - disk2 - disk3 + environment: "{{ deployment_environment_variables | default({}) }}" + tags: - deploy-vms diff --git a/multi-node-aio/playbooks/setup-host.yml b/multi-node-aio/playbooks/setup-host.yml index 1a15089b..a5e0abc3 100644 --- a/multi-node-aio/playbooks/setup-host.yml +++ b/multi-node-aio/playbooks/setup-host.yml @@ -270,6 +270,8 @@ apt: update_cache: yes + environment: "{{ deployment_environment_variables | default({}) }}" + handlers: - name: reload acng service: