| ==================== |
| Deploy cfg01 locally |
| ==================== |
| |
| Deploy cfg01 on Ubuntu with QEMU/KVM (libvirt) |
| ============================================== |
| |
| **Prerequisites** |
| |
| Script will check and install next required packages: qemu-utils libvirt-bin virtinst qemu-kvm. |
| |
| **Common info** |
| |
| Script gives you an ability to deploy cfg01 VM with provided cfg01 Qcwo2 disk |
| image and config-drive iso file on your local laptop. |
| |
| Script is operating by next ENV variables: |
| |
| * VM_NAME - the name of VM to be created in VirtualBox. Default: 'cfg01-mcp.local'. |
| * VM_SOURCE_DISK - the name of virtual disk to be used for virtual machine. Can be relative or absolute path. |
| * VM_CONFIG_DISK - same as VM_SOURCE_DISK, but for config-drive ISO file. |
| * VM_MGM_BRIDGE_NAME - Bridge name to use for deploy management network. Should have Internet access if not |
| offline case. Optional, default: 'br-mgm' |
| * VM_CTL_BRIDGE_NAME - Bridge name to use for control network. Optional, default: 'br-ctl' |
| * VM_MGM_BRIDGE_DISABLE - Do not use host bridge for deploy management network and create new nat-network. |
| Optional, default: false |
| * VM_CTL_BRIDGE_DISABLE - Do not use host bridge for control network and create host-only based new network. |
| Optional, default: false |
| * VM_MGM_NETWORK_NAME - Name for deploy management network. Optional, default: 'mgm_network' |
| * VM_CTL_NETWORK_NAME - Name for control network. Optional, default: 'ctl_network' |
| * VM_MGM_NETWORK_GATEWAY - NAT-Service network gateway for deploy management network. |
| Optional, default: '192.168.15.1' |
| * VM_MGM_NETWORK_MASK - Network mask for deploy management network. Optional, default: '255.255.255.0' |
| * VM_CTL_NETWORK_GATEWAY - Host-only based network gateway for control network. |
| Optional, default: '192.168.56.1' |
| * VM_CTL_NETWORK_MASK - Network mask for control network. Optional, default: '255.255.255.0' |
| |
| Script will check that disk and config-drive are present and then define needed networks and spawn virtual machine. |
| Then check that VM is up and running. |
| |
| Once VM is up and running you can use ``virsh console`` to check what is going on during deploy. |
| It is recommended to specify username and password during model generation for login via VM console if |
| something goes wrong. Once you are logged in you can follow usual debug procedure for cfg01 node. |
| |
| |
| Deploy cfg01 on Mac OS with VirtualBox |
| ====================================== |
| |
| **Prerequisites** |
| |
| Recommended VirtualBox version is 5.2.26, with Extenstion pack for the same version: |
| |
| * Get VirtualBox package for your system: https://download.virtualbox.org/virtualbox/5.2.26/ |
| * Extension pack: https://download.virtualbox.org/virtualbox/5.2.26/Oracle_VM_VirtualBox_Extension_Pack-5.2.26.vbox-extpack |
| * Python JSON module |
| |
| **Common info** |
| |
| Script gives you an ability to deploy cfg01 VM with provided cfg01 VDI disk |
| image and config-drive iso file on your local laptop. |
| |
| Script takes as arguments two URLs: for cfg01 disk image and for config-drive ISO file. |
| Both arguments are required in specified order. All other parameters are optional and can |
| be overrided by exporting them via 'export' command or by creating in script's |
| run directory env file 'env_overrides' with next possible arguments: |
| |
| * VM_NAME - the name of VM to be created in VirtualBox. Default: 'cfg01-mcp.local'. |
| * VM_DISK - the name of virtual disk to be used for virtual machine. Can be |
| an absolute path as well. This variable will be used as target file name for |
| downloading virtual machine disk, please be sure that path exists. |
| Default: 'cfg01-disk.vdi' |
| * CONFIG_DRIVE_ISO - same as VM_DISK, but for config-drive ISO file. |
| Default: 'cfg01.deploy-local.local-config.iso' |
| * AUTO_USER_CONFIRM - do not ask user confirmation to override some resource if already exists. |
| Default: false |
| * UPDATE_ISO_INTERFACES - Update network settings in provided config-drive ISO file. |
| The target and main hosts, which is used to deploy cfg01 instance, are based under |
| OS Linux family and QEMU/KVM virtualization and virtio net-driver. Xenial system, which |
| used for cfg01, already contains a new SystemD predictable network interface names mechanism [0], |
| which automatically assigns ens[3-9] interface names for VMs. VirtualBox is using multi-functional |
| network card, which leads to renaming all network interfaces to enp0s* names. |
| [0] https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames/ |
| Default: true |
| |
| * DEPLOY_NET_NAME - NAT-Service network name, which is used as primary interface for cfg01. This network |
| doesn't provided direct access to VM, it is possible to add manually port forwarding rules if needed, but |
| for VM access use host-only network CONTROL_NET. Default: 'deploy_nat_network' |
| * DEPLOY_NETWORK - NAT-Service network with CIDR to use. Should be same as on model generation |
| step 'networking'. Default: '192.168.15.0/24' |
| * DEPLOY_GATEWAY - NAT-Service network gateway. Should be same as on model generation step 'networking'. |
| Default: '192.168.15.1' |
| * DEPLOY_IP_ADDRESS - Primary deploy IP address, which is also specified during model generation. |
| Default: '192.168.15.15' |
| |
| * CONTROL_NET_NAME - Host-only based network name, which has static names 'vboxnetX', where 'X' is simple |
| count of existing networks for such type. Default: 'vboxnet0' |
| * CONTROL_GATEWAY - Host-only based network gateway. Default: '192.168.56.1' |
| * CONTROL_NETWORK - Host-only based network with CIDR to use. Should be same as on model generation |
| step 'networking'. Default: '192.168.56.0/24' |
| * CONTROL_IP_ADDRESS - Control IP address, which is also specified during model generation. |
| Default: '192.168.56.15' |
| |
| Script will go through next steps: |
| |
| * Download disk image and config drive ISO; |
| * Define virtual machine with provided parameters; |
| * If needed config-drive ISO network data will be updated on a fly; |
| * Run virtual machine. |
| |
| Once VM is up and running you can use VirtualBox VM console to check what is going on during deploy. |
| It will drop all logs into console and it doesn't matter loged in user or not. It is recommended to specify |
| username and password during model generation for login via VM console if something goes wrong. |
| Once you are logged in you can follow usual debug procedure for cfg01 node. |