diff options
Diffstat (limited to 'playbooks/libvirt')
7 files changed, 53 insertions, 30 deletions
| diff --git a/playbooks/libvirt/openshift-cluster/cluster_hosts.yml b/playbooks/libvirt/openshift-cluster/cluster_hosts.yml index b989e15fa..a7baea915 100644 --- a/playbooks/libvirt/openshift-cluster/cluster_hosts.yml +++ b/playbooks/libvirt/openshift-cluster/cluster_hosts.yml @@ -16,6 +16,6 @@ g_node_hosts:    "{{ g_all_hosts | intersect(groups['tag_host-type-node'] | defa  g_new_node_hosts: "{{ g_all_hosts | intersect(groups['tag_host-type-new-node'] | default([])) }}" -g_infra_hosts:   "{{ g_node_hosts | intersect(groups['tag_sub-host-type-infra']) | default([]) }}" +g_infra_hosts:   "{{ g_node_hosts | intersect(groups['tag_sub-host-type-infra'] | default([])) }}"  g_compute_hosts: "{{ g_node_hosts | intersect(groups['tag_sub-host-type-compute'] | default([])) }}" diff --git a/playbooks/libvirt/openshift-cluster/launch.yml b/playbooks/libvirt/openshift-cluster/launch.yml index 3a48c82bc..701d57d26 100644 --- a/playbooks/libvirt/openshift-cluster/launch.yml +++ b/playbooks/libvirt/openshift-cluster/launch.yml @@ -7,9 +7,6 @@    vars_files:    - vars.yml    vars: -    os_libvirt_storage_pool: "{{ libvirt_storage_pool | default('images') }}" -    os_libvirt_storage_pool_path: "{{ libvirt_storage_pool_path | default('/var/lib/libvirt/images') }}" -    os_libvirt_network: "{{ libvirt_network | default('default') }}"      image_url: "{{ deployment_vars[deployment_type].image.url }}"      image_sha256: "{{ deployment_vars[deployment_type].image.sha256 }}"      image_name: "{{ deployment_vars[deployment_type].image.name }}" diff --git a/playbooks/libvirt/openshift-cluster/tasks/launch_instances.yml b/playbooks/libvirt/openshift-cluster/tasks/launch_instances.yml index b00352539..937a765fa 100644 --- a/playbooks/libvirt/openshift-cluster/tasks/launch_instances.yml +++ b/playbooks/libvirt/openshift-cluster/tasks/launch_instances.yml @@ -13,54 +13,58 @@    get_url:      url: '{{ image_url }}'      sha256sum: '{{ image_sha256 }}' -    dest: '{{ os_libvirt_storage_pool_path }}/{{ [image_name, image_compression] | reject("equalto", "") | join(".") }}' +    dest: '{{ libvirt_storage_pool_path }}/{{ [image_name, image_compression] | difference([""]) | join(".") }}'    when: '{{ ( lookup("oo_option", "skip_image_download") | default("no", True) | lower ) in ["false", "no"] }}'    register: downloaded_image  - name: Uncompress xz compressed base cloud image -  command: 'unxz -kf {{ os_libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}' +  command: 'unxz -kf {{ libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}'    args: -    creates: '{{ os_libvirt_storage_pool_path }}/{{ image_name }}' +    creates: '{{ libvirt_storage_pool_path }}/{{ image_name }}'    when: image_compression in ["xz"] and downloaded_image.changed  - name: Uncompress tgz compressed base cloud image -  command: 'tar zxvf {{ os_libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}' +  command: 'tar zxvf {{ libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}'    args: -    creates: '{{ os_libvirt_storage_pool_path }}/{{ image_name }}' +    creates: '{{ libvirt_storage_pool_path }}/{{ image_name }}'    when: image_compression in ["tgz"] and downloaded_image.changed  - name: Uncompress gzip compressed base cloud image -  command: 'gunzip {{ os_libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}' +  command: 'gunzip {{ libvirt_storage_pool_path }}/{{ [image_name, image_compression] | join(".") }}'    args: -    creates: '{{ os_libvirt_storage_pool_path }}/{{ image_name }}' +    creates: '{{ libvirt_storage_pool_path }}/{{ image_name }}'    when: image_compression in ["gz"] and downloaded_image.changed  - name: Create the cloud-init config drive path    file: -    dest: '{{ os_libvirt_storage_pool_path }}/{{ item }}_configdrive/' +    dest: '{{ libvirt_storage_pool_path }}/{{ item }}_configdrive/'      state: directory    with_items: instances  - name: Create the cloud-init config drive files    template:      src: '{{ item[1] }}' -    dest: '{{ os_libvirt_storage_pool_path }}/{{ item[0] }}_configdrive/{{ item[1] }}' +    dest: '{{ libvirt_storage_pool_path }}/{{ item[0] }}_configdrive/{{ item[1] }}'    with_nested:      - instances      - [ user-data, meta-data ]  - name: Create the cloud-init config drive -  command: 'genisoimage -output {{ os_libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso -volid cidata -joliet -rock user-data meta-data' +  command: 'genisoimage -output {{ libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso -volid cidata -joliet -rock user-data meta-data'    args: -    chdir: '{{ os_libvirt_storage_pool_path }}/{{ item }}_configdrive/' -    creates: '{{ os_libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso' +    chdir: '{{ libvirt_storage_pool_path }}/{{ item }}_configdrive/' +    creates: '{{ libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso'    with_items: instances  - name: Refresh the libvirt storage pool for openshift    command: 'virsh -c {{ libvirt_uri }} pool-refresh {{ libvirt_storage_pool }}' -- name: Create VMs drives -  command: 'virsh -c {{ libvirt_uri }} vol-create-as {{ os_libvirt_storage_pool }} {{ item }}.qcow2 10G --format qcow2 --backing-vol {{ image_name }} --backing-vol-format qcow2' +- name: Create VM drives +  command: 'virsh -c {{ libvirt_uri }} vol-create-as {{ libvirt_storage_pool }} {{ item }}.qcow2 10G --format qcow2 --backing-vol {{ image_name }} --backing-vol-format qcow2' +  with_items: instances + +- name: Create VM docker drives +  command: 'virsh -c {{ libvirt_uri }} vol-create-as {{ libvirt_storage_pool }} {{ item }}-docker.qcow2 10G --format qcow2 --allocation 0'    with_items: instances  - name: Create VMs diff --git a/playbooks/libvirt/openshift-cluster/templates/domain.xml b/playbooks/libvirt/openshift-cluster/templates/domain.xml index 0ca8e0974..8e96cec8d 100644 --- a/playbooks/libvirt/openshift-cluster/templates/domain.xml +++ b/playbooks/libvirt/openshift-cluster/templates/domain.xml @@ -1,6 +1,6 @@  <domain type='kvm' id='8'>    <name>{{ item }}</name> -  <memory unit='GiB'>1</memory> +  <memory unit='MiB'>{{ libvirt_instance_memory_mib }}</memory>    <metadata xmlns:ansible="https://github.com/ansible/ansible">      <ansible:tags>        <ansible:tag>environment-{{ cluster_env }}</ansible:tag> @@ -9,8 +9,7 @@        <ansible:tag>sub-host-type-{{ g_sub_host_type }}</ansible:tag>      </ansible:tags>    </metadata> -  <currentMemory unit='GiB'>1</currentMemory> -  <vcpu placement='static'>2</vcpu> +  <vcpu placement='static'>{{ libvirt_instance_vcpu }}</vcpu>    <os>      <type arch='x86_64' machine='pc'>hvm</type>      <boot dev='hd'/> @@ -32,18 +31,23 @@      <emulator>/usr/bin/qemu-system-x86_64</emulator>      <disk type='file' device='disk'>        <driver name='qemu' type='qcow2'/> -      <source file='{{ os_libvirt_storage_pool_path }}/{{ item }}.qcow2'/> +      <source file='{{ libvirt_storage_pool_path }}/{{ item }}.qcow2'/>        <target dev='vda' bus='virtio'/>      </disk> +    <disk type='file' device='disk'> +      <driver name='qemu' type='qcow2'/> +      <source file='{{ libvirt_storage_pool_path }}/{{ item }}-docker.qcow2'/> +      <target dev='vdb' bus='virtio'/> +    </disk>      <disk type='file' device='cdrom'>        <driver name='qemu' type='raw'/> -      <source file='{{ os_libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso'/> -      <target dev='vdb' bus='virtio'/> +      <source file='{{ libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso'/> +      <target dev='vdc' bus='virtio'/>        <readonly/>      </disk>      <controller type='usb' index='0' />      <interface type='network'> -      <source network='{{ os_libvirt_network }}'/> +      <source network='{{ libvirt_network }}'/>        <model type='virtio'/>      </interface>      <serial type='pty'> diff --git a/playbooks/libvirt/openshift-cluster/templates/user-data b/playbooks/libvirt/openshift-cluster/templates/user-data index ead881f78..8b79940f4 100644 --- a/playbooks/libvirt/openshift-cluster/templates/user-data +++ b/playbooks/libvirt/openshift-cluster/templates/user-data @@ -4,6 +4,9 @@ disable_root: true  hostname: {{ item[0] }}  fqdn: {{ item[0] }}.example.com +mounts: +- [ vdb ] +  users:    - default    - name: root @@ -23,6 +26,12 @@ write_files:      permissions: 440      content: |          Defaults:openshift !requiretty +  - content: | +      DEVS=/dev/vdb +      VG=docker_vg +    path: /etc/sysconfig/docker-storage-setup +    owner: root:root +    permissions: '0644'  runcmd:    - NETWORK_CONFIG=/etc/sysconfig/network-scripts/ifcfg-eth0; if ! grep DHCP_HOSTNAME ${NETWORK_CONFIG}; then echo 'DHCP_HOSTNAME="{{ item[0] }}.example.com"' >> ${NETWORK_CONFIG}; fi; pkill -9 dhclient; service network restart diff --git a/playbooks/libvirt/openshift-cluster/terminate.yml b/playbooks/libvirt/openshift-cluster/terminate.yml index f4749c28d..d6251ac83 100644 --- a/playbooks/libvirt/openshift-cluster/terminate.yml +++ b/playbooks/libvirt/openshift-cluster/terminate.yml @@ -45,12 +45,18 @@      - groups['oo_hosts_to_terminate']      - [ destroy, undefine ] -  - name: Delete VMs drives +  - name: Delete VM drives      command: 'virsh -c {{ libvirt_uri }} vol-delete --pool {{ libvirt_storage_pool }} {{ item }}.qcow2'      args:        removes: '{{ libvirt_storage_pool_path }}/{{ item }}.qcow2'      with_items: groups['oo_hosts_to_terminate'] +  - name: Delete VM docker drives +    command: 'virsh -c {{ libvirt_uri }} vol-delete --pool {{ libvirt_storage_pool }} {{ item }}-docker.qcow2' +    args: +      removes: '{{ libvirt_storage_pool_path }}/{{ item }}-docker.qcow2' +    with_items: groups['oo_hosts_to_terminate'] +    - name: Delete the VM cloud-init image      file:        path: '{{ libvirt_storage_pool_path }}/{{ item }}_cloud-init.iso' diff --git a/playbooks/libvirt/openshift-cluster/vars.yml b/playbooks/libvirt/openshift-cluster/vars.yml index f28245f88..aa0c69e08 100644 --- a/playbooks/libvirt/openshift-cluster/vars.yml +++ b/playbooks/libvirt/openshift-cluster/vars.yml @@ -1,8 +1,11 @@  --- -libvirt_storage_pool_path: "{{ lookup('env','HOME') }}/libvirt-storage-pool-openshift-ansible" -libvirt_storage_pool: 'openshift-ansible' -libvirt_network: openshift-ansible -libvirt_uri: 'qemu:///system' +default_pool_path: "{{ lookup('env','HOME') }}/libvirt-storage-pool-openshift-ansible" +libvirt_storage_pool_path: "{{ lookup('oo_option', 'libvirt_storage_pool_path') | default(default_pool_path, True) }}" +libvirt_storage_pool: "{{ lookup('oo_option', 'libvirt_storage_pool') | default('openshift-ansible', True) }}" +libvirt_network: "{{ lookup('oo_option', 'libvirt_network') | default('openshift-ansible', True) }}" +libvirt_instance_memory_mib: "{{ lookup('oo_option', 'libvirt_instance_memory_mib') | default(1024, True) }}" +libvirt_instance_vcpu: "{{ lookup('oo_option', 'libvirt_instance_vcpu') | default(2, True) }}" +libvirt_uri: "{{ lookup('oo_option', 'libvirt_uri') | default('qemu:///system', True) }}"  debug_level: 2  # Automatic download of the qcow2 image for RHEL cannot be done directly from the RedHat portal because it requires authentication. | 
