Initial support for diskimage-builder
Changing the process over to utilize diskimage-builder as it has support for building images that will boot utilizing configuration drives.
This commit is contained in:
parent
f4ed4a5376
commit
70169451cf
@ -0,0 +1,4 @@
|
|||||||
|
---
|
||||||
|
- name: "Initiate image build"
|
||||||
|
shell: disk-image-create -a amd64 -o "{{http_boot_folder}}/{{deploy_image_filename}}" -t qcow2 vm ubuntu serial-console cloud-init-datasources "{{ extra_dib_elements}}"
|
||||||
|
environment: dib_env_vars
|
@ -0,0 +1,11 @@
|
|||||||
|
---
|
||||||
|
- name: "Shade - Retrieving diskimage-builder from git.openstack.org"
|
||||||
|
local_action: command git clone https://git.openstack.org/openstack/diskimage-builder chdir=/opt/stack creates=/opt/stack/diskimage-builder
|
||||||
|
- name: "Shade - Checking out master branch"
|
||||||
|
local_action: command git checkout -f master chdir=/opt/stack/diskimage-builder
|
||||||
|
- name: "Shade - Resetting local repository"
|
||||||
|
local_action: command git reset --hard master chdir=/opt/stack/diskimage-builder
|
||||||
|
- name: "Shade - Resyncing local repository"
|
||||||
|
local_action: command git pull --ff-only chdir=/opt/stack/diskimage-builder
|
||||||
|
- name: "Shade - Installing patched library."
|
||||||
|
local_action: command pip install -I --force-reinstall /opt/stack/diskimage-builder
|
@ -74,6 +74,9 @@
|
|||||||
local_action: command git pull --ff-only chdir=/opt/stack/shade
|
local_action: command git pull --ff-only chdir=/opt/stack/shade
|
||||||
- name: "Shade - Installing patched shade library."
|
- name: "Shade - Installing patched shade library."
|
||||||
local_action: command pip install -I --force-reinstall /opt/stack/shade
|
local_action: command pip install -I --force-reinstall /opt/stack/shade
|
||||||
|
- name: "Include diskimage-builder installation"
|
||||||
|
include: dib_install.yml
|
||||||
|
when: create_image_via_dib == true
|
||||||
- name: "Starting MySQL"
|
- name: "Starting MySQL"
|
||||||
local_action: service name=mysql state=started
|
local_action: service name=mysql state=started
|
||||||
- name: "Starting rabbitmq-server"
|
- name: "Starting rabbitmq-server"
|
||||||
@ -200,9 +203,13 @@
|
|||||||
# Anything better!
|
# Anything better!
|
||||||
- name: "Download Ubuntu image"
|
- name: "Download Ubuntu image"
|
||||||
local_action: get_url url=http://cloud-images.ubuntu.com/releases/trusty/release/ubuntu-14.04-server-cloudimg-amd64.tar.gz dest=/httpboot/ubuntu-14.04-server-cloudimg-amd64.tar.gz
|
local_action: get_url url=http://cloud-images.ubuntu.com/releases/trusty/release/ubuntu-14.04-server-cloudimg-amd64.tar.gz dest=/httpboot/ubuntu-14.04-server-cloudimg-amd64.tar.gz
|
||||||
when: test_os_image_present.stat.exists == false
|
when: test_os_image_present.stat.exists == false and create_image_via_dib == false
|
||||||
- name: "Extract Ubuntu image"
|
- name: "Extract Ubuntu image"
|
||||||
local_action: command tar -xvzf ubuntu-14.04-server-cloudimg-amd64.tar.gz chdir=/httpboot creates=/httpboot/trusty-server-cloudimg-amd64.img
|
local_action: command tar -xvzf ubuntu-14.04-server-cloudimg-amd64.tar.gz chdir=/httpboot creates=/httpboot/trusty-server-cloudimg-amd64.img
|
||||||
when: test_os_image_present.stat.exists == false
|
when: test_os_image_present.stat.exists == false and create_image_via_dib == false
|
||||||
- include: create_bootable_image.yaml
|
- name: "Creating bootable image"
|
||||||
when: test_os_image_present.stat.exists == false and transform_boot_image == true
|
include: create_bootable_image.yml
|
||||||
|
when: test_os_image_present.stat.exists == false and transform_boot_image == true and create_image_via_dib == false
|
||||||
|
- name: "Creating image via disk imae builder"
|
||||||
|
include: create_dib_image.yml
|
||||||
|
when: test_os_image_present.stat.exists == false and transform_boot_image == false and create_image_via_dib == true
|
||||||
|
@ -28,5 +28,10 @@ required_packages_ubuntu:
|
|||||||
http_boot_folder: /httpboot
|
http_boot_folder: /httpboot
|
||||||
transform_boot_image: false
|
transform_boot_image: false
|
||||||
ironic_url: "http://localhost:6385/"
|
ironic_url: "http://localhost:6385/"
|
||||||
network_interface: "eth0"
|
|
||||||
ssh_public_key_path: "{{ ansible_env.HOME }}/.ssh/id_rsa.pub"
|
ssh_public_key_path: "{{ ansible_env.HOME }}/.ssh/id_rsa.pub"
|
||||||
|
dib_env_vars:
|
||||||
|
DIB_CLOUD_INIT_DATASOURCES: "ConfigDrive"
|
||||||
|
# extra_dib_elements is a space separated list of elements.
|
||||||
|
extra_dib_elements: ""
|
||||||
|
create_image_via_dib: true
|
||||||
|
transform_boot_image: false
|
||||||
|
@ -15,7 +15,6 @@ deploy_ramdisk_url: "http://{{ hostvars[inventory_hostname]['ansible_' + network
|
|||||||
deploy_image_filename: "trusty-server-cloudimg-amd64.img"
|
deploy_image_filename: "trusty-server-cloudimg-amd64.img"
|
||||||
deploy_image: "{{http_boot_folder}}/{{deploy_image_filename}}"
|
deploy_image: "{{http_boot_folder}}/{{deploy_image_filename}}"
|
||||||
# Transform boot image is intended for use with the Ubuntu trusty image. It makes the image bootable by ihnstalling Grub.
|
# Transform boot image is intended for use with the Ubuntu trusty image. It makes the image bootable by ihnstalling Grub.
|
||||||
transform_boot_image: true
|
|
||||||
node_default_network_interface: eth0
|
node_default_network_interface: eth0
|
||||||
# ipv4_subnet_mask is intended for the static ipv4 address assignments.
|
# ipv4_subnet_mask is intended for the static ipv4 address assignments.
|
||||||
ipv4_subnet_mask: 255.255.255.0
|
ipv4_subnet_mask: 255.255.255.0
|
||||||
|
Loading…
Reference in New Issue
Block a user