Break install role into logical chunks
The ironic-install role is getting a little unwieldy. Break out the /tftpboot setup and IPA CoreOS download into tasks to be included. Remove the Ubuntu download as it is not currently in use. Change-Id: I5043995e7f950aaea1b8ccfea362a89613efa31c
This commit is contained in:
parent
a6ff86cf2e
commit
2577caad01
46
playbooks/roles/ironic-install/tasks/create_tftpboot.yml
Normal file
46
playbooks/roles/ironic-install/tasks/create_tftpboot.yml
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
---
|
||||||
|
- name: "Setting up PXE and iPXE folders"
|
||||||
|
file: name={{item}} owner=ironic group=ironic state=directory
|
||||||
|
with_items:
|
||||||
|
- /tftpboot
|
||||||
|
- /tftpboot/pxelinux.cfg
|
||||||
|
- "{{ http_boot_folder }}"
|
||||||
|
- name: "Placing tftpd map-file"
|
||||||
|
copy: src=tftpboot-map-file dest=/tftpboot/map-file owner=ironic group=ironic
|
||||||
|
- name: "Disable service tftpd-hpa"
|
||||||
|
service: name=tftpd-hpa state=stopped enabled=no
|
||||||
|
# NOTE(cinerama) See https://bugs.launchpad.net/bifrost/+bug/1471973
|
||||||
|
# with regard to the next two tasks.
|
||||||
|
- name: "Placing pxelinux.0 (pre-14.10)"
|
||||||
|
copy: src={{ syslinux_tftp_dir }}/pxelinux.0 dest=/tftpboot
|
||||||
|
when: ansible_distribution_version|version_compare('14.10', '<')
|
||||||
|
- name: "Placing pxelinux.0 (>=14.10)"
|
||||||
|
copy: src=/usr/lib/PXELINUX/pxelinux.0 dest=/tftpboot
|
||||||
|
when: ansible_distribution_version|version_compare('14.10', '>=')
|
||||||
|
- name: "Place boot.ipxe helper script to HTTP root"
|
||||||
|
copy: src=boot.ipxe dest=/httpboot/boot.ipxe
|
||||||
|
- name: "Place tftp config file"
|
||||||
|
copy: src=xinetd.tftp dest=/etc/xinetd.d/tftp
|
||||||
|
- name: "Copy iPXE image into place"
|
||||||
|
copy: src={{ ipxe_dir }}/undionly.kpxe dest=/tftpboot/
|
||||||
|
# Similar logic to below can be utilized to retrieve files
|
||||||
|
- name: "Determine if folder exists, else create and populate folder."
|
||||||
|
stat: path=/tftpboot/master_images
|
||||||
|
register: test_master_images
|
||||||
|
- name: "Create master_images folder"
|
||||||
|
file: name=/tftpboot/master_images state=directory owner=ironic group=ironic
|
||||||
|
when: test_master_images.stat.exists == false
|
29
playbooks/roles/ironic-install/tasks/download_ipa_coreos.yml
Normal file
29
playbooks/roles/ironic-install/tasks/download_ipa_coreos.yml
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
---
|
||||||
|
# This is overly complex, however get_url will always re-retrieve the file
|
||||||
|
# if it already exists, and this is to prevent that behavior.
|
||||||
|
- name: "Test if CoreOS kernel is present"
|
||||||
|
stat: path={{ http_boot_folder }}/coreos_production_pxe.vmlinuz
|
||||||
|
register: test_core_os_kernel_present
|
||||||
|
- name: "Download CoreOS kernel"
|
||||||
|
get_url: url={{ deploy_kernel_upstream_url }} dest={{ http_boot_folder }}/coreos_production_pxe.vmlinuz
|
||||||
|
when: test_core_os_kernel_present.stat.exists == false
|
||||||
|
- name: "Test if CoreOS image is present"
|
||||||
|
stat: path={{ http_boot_folder }}/coreos_production_pxe_image-oem.cpio.gz
|
||||||
|
register: test_core_os_image_present
|
||||||
|
- name: "Download CoreOS image"
|
||||||
|
get_url: url={{ deploy_ramdisk_upstream_url }} dest={{ http_boot_folder }}/coreos_production_pxe_image-oem.cpio.gz
|
||||||
|
when: test_core_os_image_present.stat.exists == false
|
@ -150,28 +150,8 @@
|
|||||||
service: name=ironic-conductor state=restarted
|
service: name=ironic-conductor state=restarted
|
||||||
- name: "Start ironic-api"
|
- name: "Start ironic-api"
|
||||||
service: name=ironic-api state=restarted
|
service: name=ironic-api state=restarted
|
||||||
- name: "Setting up PXE and iPXE folders"
|
- name: "Create and populate /tftpboot"
|
||||||
file: name={{item}} owner=ironic group=ironic state=directory
|
include: create_tftpboot.yml
|
||||||
with_items:
|
|
||||||
- /tftpboot
|
|
||||||
- /tftpboot/pxelinux.cfg
|
|
||||||
- "{{ http_boot_folder }}"
|
|
||||||
- name: "Placing tftpd map-file"
|
|
||||||
copy: src=tftpboot-map-file dest=/tftpboot/map-file owner=ironic group=ironic
|
|
||||||
- name: "Disable service tftpd-hpa"
|
|
||||||
service: name=tftpd-hpa state=stopped enabled=no
|
|
||||||
- name: "Placing pxelinux.0 (pre-14.10)"
|
|
||||||
copy: src={{ syslinux_tftp_dir }}/pxelinux.0 dest=/tftpboot
|
|
||||||
when: ansible_distribution_version|version_compare('14.10', '<')
|
|
||||||
- name: "Placing pxelinux.0 (>=14.10)"
|
|
||||||
copy: src=/usr/lib/PXELINUX/pxelinux.0 dest=/tftpboot
|
|
||||||
when: ansible_distribution_version|version_compare('14.10', '>=')
|
|
||||||
- name: "Place boot.ipxe helper script to HTTP root"
|
|
||||||
copy: src=boot.ipxe dest=/httpboot/boot.ipxe
|
|
||||||
- name: "Place tftp config file"
|
|
||||||
copy: src=xinetd.tftp dest=/etc/xinetd.d/tftp
|
|
||||||
- name: "Copy iPXE image into place"
|
|
||||||
copy: src={{ ipxe_dir }}/undionly.kpxe dest=/tftpboot/
|
|
||||||
- name: "Deploy dnsmasq configuration file"
|
- name: "Deploy dnsmasq configuration file"
|
||||||
template: src=dnsmasq.conf.j2 dest=/etc/dnsmasq.conf
|
template: src=dnsmasq.conf.j2 dest=/etc/dnsmasq.conf
|
||||||
when: "{{include_dhcp_server|bool}}"
|
when: "{{include_dhcp_server|bool}}"
|
||||||
@ -224,39 +204,14 @@
|
|||||||
- name: "Sending services a force-reload signal"
|
- name: "Sending services a force-reload signal"
|
||||||
service: name=dnsmasq state=restarted
|
service: name=dnsmasq state=restarted
|
||||||
when: "{{include_dhcp_server|bool}}"
|
when: "{{include_dhcp_server|bool}}"
|
||||||
# Similar logic to below can be utilized to retrieve files
|
- name: "Download Ironic Python Agent CoreOS kernel & image"
|
||||||
- name: "Determine if folder exists, else create and populate folder."
|
include: download_ipa_coreos.yml
|
||||||
stat: path=/tftpboot/master_images
|
|
||||||
register: test_master_images
|
|
||||||
- name: "Create master_images folder"
|
|
||||||
file: name=/tftpboot/master_images state=directory owner=ironic group=ironic
|
|
||||||
when: test_master_images.stat.exists == false
|
|
||||||
# This is overly complex, however get_url will always re-retrieve the file
|
|
||||||
# if it already exists, and this is to prevent that behavior.
|
|
||||||
- name: "Test if CoreOS kernel is present"
|
|
||||||
stat: path={{ http_boot_folder }}/coreos_production_pxe.vmlinuz
|
|
||||||
register: test_core_os_kernel_present
|
|
||||||
- name: "Download CoreOS kernel"
|
|
||||||
get_url: url={{ deploy_kernel_upstream_url }} dest={{ http_boot_folder }}/coreos_production_pxe.vmlinuz
|
|
||||||
when: test_core_os_kernel_present.stat.exists == false
|
|
||||||
- name: "Test if CoreOS image is present"
|
|
||||||
stat: path={{ http_boot_folder }}/coreos_production_pxe_image-oem.cpio.gz
|
|
||||||
register: test_core_os_image_present
|
|
||||||
- name: "Download CoreOS image"
|
|
||||||
get_url: url={{ deploy_ramdisk_upstream_url }} dest={{ http_boot_folder }}/coreos_production_pxe_image-oem.cpio.gz
|
|
||||||
when: test_core_os_image_present.stat.exists == false
|
|
||||||
- name: "Download cirros to use for deployment if requested"
|
- name: "Download cirros to use for deployment if requested"
|
||||||
get_url: url={{ cirros_deploy_image_upstream_url }} dest="{{ deploy_image }}"
|
get_url: url={{ cirros_deploy_image_upstream_url }} dest="{{ deploy_image }}"
|
||||||
when: "{{use_cirros|bool}}"
|
when: "{{use_cirros|bool}}"
|
||||||
- name: "Test if Ubuntu 14.04 server cloud amd64 is present"
|
- name: "Test if deploy image is present"
|
||||||
stat: path={{ deploy_image }}
|
stat: path={{ deploy_image }}
|
||||||
register: test_os_image_present
|
register: test_os_image_present
|
||||||
- name: "Download Ubuntu image"
|
|
||||||
get_url: url={{ deploy_image_upstream_url }} dest=/httpboot/ubuntu-14.04-server-cloudimg-amd64.tar.gz
|
|
||||||
when: test_os_image_present.stat.exists == false and create_image_via_dib == false
|
|
||||||
- name: "Extract Ubuntu image"
|
|
||||||
unarchive: src=/httpboot/ubuntu-14.04-server-cloudimg-amd64.tar.gz dest=/httpboot/ creates=/httpboot/trusty-server-cloudimg-amd64.img
|
|
||||||
when: test_os_image_present.stat.exists == false and create_image_via_dib == false
|
|
||||||
# Create bootable image takes a partition image, prepends space for a
|
# Create bootable image takes a partition image, prepends space for a
|
||||||
# bootloader, partition table, and then installs the bootloader.
|
# bootloader, partition table, and then installs the bootloader.
|
||||||
#
|
#
|
||||||
|
Loading…
x
Reference in New Issue
Block a user