/ansible-role-windows_ovirt_template

This repo contains an Ansible role that builds a Windows VM template from an ISO file on Ovirt/RHV.

Primary LanguageJinjaMIT LicenseMIT

windows_ovirt_template

This repo contains an Ansible role that builds a Windows VM template from an ISO file on Ovirt/RHV. You can run this role as a part of CI/CD pipeline for building Windows templates on Ovirt/RHV from an ISO file.

Note: This role is provided as an example only. Do not use this in production. You can fork/clone and add/remove steps for your environment based on your organization's security and operational requirements.

Requirements

You need to have the following packages installed on your ansible control machine:

  • mkisofs

You need to enable qemu_cmdline hook on your RHV/Ovirt environment, this is required to enable attaching multiple iso files. Follow the instructions documented here:

https://www.ovirt.org/develop/developer-guide/vdsm/hook/qemucmdline.html

Before you can use this role, you need to make sure you have Windows install media iso file uploaded to a iso domain on your RHV/Ovirt environment.

Role Variables

A description of the settable variables for this role should go here, including any variables that are in defaults/main.yml, vars/main.yml, and any variables that can/should be set via parameters to the role. Any variables that are read from other roles and/or the global scope (ie. hostvars, group vars, etc.) should be mentioned here as well.

Dependencies

Import ovirt.ovirt collections.

A list of roles that this role utilizes, make sure to call this out in requirements.yml file under roles directory or download manually:

  • oatakan.windows_template_build

Example Playbook

Including an example of how to use your role (for instance, with variables passed in as parameters) is always nice for users too:

---
# import ovirt.ovirt collections
- name: create a ovirt windows template
  hosts: all
  gather_facts: false
  connection: local
  become: false
  vars:
    template_force: true #overwrite existing template with the same name
    export_ovf: false # export the template to export domain upon creation
    local_account_password: ''
    local_administrator_password: ''
    distro_name: win2019 # this needs to be one of the standard values see 'os_short_names' var
    template_vm_name: win2019_template
    template_vm_root_disk_size: 30
    template_vm_guest_id: windows_2019x64
    template_vm_memory: 4096
    template_vm_efi: false # you need to install efi file to use this, false should be fine in most cases
    iso_file_name: '' # name of the iso file
    iso_image_index: '' # put index number here from the order inside the iso, for example 1 - standard, 2 - core etc
    iso_product_key: ''
    vm_ansible_port: 5986
    vm_ansible_winrm_transport: credssp
    vm_upgrade_powershell: false # only needed for 2008 R2
    install_updates: false # it will take longer to build with the updates, set to true if you want the updates
    
    ovirt_datacenter: '' # name of the datacenter
    ovirt_cluster: '' # name of the cluster
    ovirt_data_domain: '' # name of the data domain
    ovirt_export_domain: '' # name of the iso domain
    ovirt_iso_domain: '' # this is deprecated as of 4.3 you can omit if not used
    
    template_vm_network_name: ovirtmgmt
    template_vm_ip_address: 192.168.10.95 # static ip is required
    template_vm_netmask: 255.255.255.0
    template_vm_gateway: 192.168.10.254
    template_vm_domain: example.com
    template_vm_dns_servers:
    - 8.8.4.4
    - 8.8.8.8

  roles:
    - oatakan.windows_ovirt_template

---
# import ovirt.ovirt collections
- name: delete a ovirt windows template
  hosts: all
  gather_facts: false
  connection: local
  become: false

  roles:
    - role: oatakan.windows_ovirt_template
      role_action: deprovision

For disconnected environments, you can overwrite this variable to point to a local copy of a script to enable winrm:

winrm_enable_script_url: https://raw.githubusercontent.com/ansible/ansible/devel/examples/scripts/ConfigureRemotingForAnsible.ps1

you can also localize virtio-win and update the virtio_iso_url variable to point to your local url:

virtio_iso_url: https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-virtio/virtio-win-0.1.173-2/virtio-win.iso

License

MIT

Author Information

Orcun Atakan