mirror of
				https://github.com/vyos/vyos-documentation.git
				synced 2025-10-26 08:41:46 +01:00 
			
		
		
		
	Automation/Cloud-init - Add how to implement cloud-init on VyOS in Proxmox environment.
This commit is contained in:
		
							parent
							
								
									fe18c3c428
								
							
						
					
					
						commit
						fc94599505
					
				| @ -233,3 +233,189 @@ most important data filtering output for ``vyos`` keyword: | ||||
| 
 | ||||
|     sudo grep vyos /var/log/cloud-init.log | ||||
| 
 | ||||
| ********************* | ||||
| Cloud-init on Proxmox | ||||
| ********************* | ||||
| 
 | ||||
| Before starting, please refer to cloud-init `network-config-docs`_ in order to | ||||
| know how to import user and network configurations. | ||||
| 
 | ||||
| Most important keys that needs to be considered: | ||||
| 
 | ||||
| * VyOS configuration commands are defined in user-data file. | ||||
| 
 | ||||
| * Networking configurations shouldn't be passed in user-data file. | ||||
| 
 | ||||
| * If no networking configuration is provided, then dhcp client is going to be | ||||
|   enabled on first interface. Bare in mind that this configuration will be | ||||
|   inyected at an OS level, so don't expect to find dhcp client configuration | ||||
|   on vyos cli. Because of this behavior, in next example lab we will disable | ||||
|   dhcp-client configuration on eth0. | ||||
| 
 | ||||
|   Also, this lab considers: | ||||
|    | ||||
| * Proxmox IP address: **192.168.0.253/24** | ||||
| 
 | ||||
| * Storaged used: volume local, which is mounted on directory **/var/lib/vz**, | ||||
|   and contains all type of content, including snippets. | ||||
| 
 | ||||
| * Remove default dhcp client on first interface, and load other | ||||
|   configuration during first boot, using cloud-init. | ||||
| 
 | ||||
| ------------------- | ||||
| Generate qcow image | ||||
| ------------------- | ||||
| 
 | ||||
| A VyOS qcow image with cloud-init options is needed. This can be obteined | ||||
| using `vyos-vm-images`_ repo. After clonning the repo, edit the file | ||||
| **qemu.yml** and comment the **download-iso** role. | ||||
| 
 | ||||
| In this lab, we are using 1.3.0 VyOS version and setting a disk of 10G. | ||||
| Download VyOS .iso file and save it as ``/tmp/vyos.iso``. Command used for | ||||
| generating qcow image: | ||||
| 
 | ||||
| .. cfgcmd:: sudo ansible-playbook qemu.yml -e disk_size=10 | ||||
|    -e iso_local=/tmp/vyos.iso -e grub_console=serial -e vyos_version=1.3.0 | ||||
|    -e cloud_init=true -e cloud_init_ds=NoCloud | ||||
| 
 | ||||
| File generated with previous command: | ||||
| ``/tmp/vyos-1.3.0-cloud-init-10G-qemu.qcow2`` | ||||
| 
 | ||||
| Now, that file needs to be copied to proxmox server: | ||||
| 
 | ||||
| .. cfgcmd:: sudo scp /tmp/vyos-1.3.0-cloud-init-10G-qemu.qcow2 | ||||
|    root@192.168.0.253:/tmp/ | ||||
| 
 | ||||
| 
 | ||||
| ------------------------ | ||||
| Prepare cloud-init files | ||||
| ------------------------ | ||||
| 
 | ||||
| In Proxmox server three files are going to be used for this setup: | ||||
| 
 | ||||
| * **network-config**: file that will indicate to avoid dhcp client on first | ||||
|   interface. | ||||
| 
 | ||||
| * **user-data**: includes vyos-commands. | ||||
| 
 | ||||
| * **meta-data**: empty file (required). | ||||
| 
 | ||||
| In this lab, all files are located in ``/tmp/``. So, before going on, lets | ||||
| move to that directory: | ||||
| 
 | ||||
| .. cfgcmd:: cd /tmp/ | ||||
| 
 | ||||
| **user-data** file must start with ``#cloud-config`` and contains | ||||
| vyos-commands. For example: | ||||
| 
 | ||||
| .. code-block:: none | ||||
| 
 | ||||
|    #cloud-config | ||||
|    vyos_config_commands: | ||||
|      - set system host-name 'vyos-BRAS' | ||||
|      - set system ntp server 1.pool.ntp.org | ||||
|      - set system ntp server 2.pool.ntp.org | ||||
|      - delete interfaces ethernet eth0 address 'dhcp' | ||||
|      - set interfaces ethernet eth0 address '198.51.100.2/30' | ||||
|      - set interfaces ethernet eth0 description 'WAN - ISP01' | ||||
|      - set interfaces ethernet eth1 address '192.168.25.1/24' | ||||
|      - set interfaces ethernet eth1 description 'Comming through VLAN 25' | ||||
|      - set interfaces ethernet eth2 address '192.168.26.1/24' | ||||
|      - set interfaces ethernet eth2 description 'Comming through VLAN 26' | ||||
|      - set protocols static route 0.0.0.0/0 next-hop '198.51.100.1' | ||||
| 
 | ||||
| **network-config** file only has configuration that disables the automatic | ||||
| dhcp client on first interface. | ||||
| 
 | ||||
| 
 | ||||
| Content of network-config file: | ||||
| 
 | ||||
| .. code-block:: none | ||||
| 
 | ||||
|    version: 2 | ||||
|    ethernets: | ||||
|      eth0: | ||||
|        dhcp4: false | ||||
|        dhcp6: false | ||||
| 
 | ||||
| Finaly, file **meta-data** has no content, but it's required. | ||||
| 
 | ||||
| --------------- | ||||
| Create seed.iso | ||||
| --------------- | ||||
| 
 | ||||
| Once the three files were created, it's time to generate the ``seed.iso`` | ||||
| image, which needs to be mounted to the new VM as a cd. | ||||
| 
 | ||||
| Command for generating ``seed.iso`` | ||||
| 
 | ||||
| .. cfgcmd:: mkisofs -joliet -rock -volid "cidata" -output seed.iso meta-data | ||||
|    user-data network-config | ||||
| 
 | ||||
| **NOTE**: be carefull while copying and pasting previous commands. Doble | ||||
| quotes may need to be corrected.  | ||||
| 
 | ||||
| --------------- | ||||
| Creating the VM | ||||
| --------------- | ||||
| 
 | ||||
| Notes for this particular example, that may need to be modified in other | ||||
| setups: | ||||
| 
 | ||||
| * VM ID: in this example, VM ID used is 555. | ||||
| 
 | ||||
| * VM Storage: ``local`` volume is used.  | ||||
| 
 | ||||
| * ISO files storage: ``local`` volume is used for ``.iso`` file storage. In | ||||
|   this scenario ``local`` volume type is set to **directory**, abd attached to | ||||
|   ``/var/lib/vz``. | ||||
| 
 | ||||
| * VM Resources: these parameters can be modified as needed. | ||||
| 
 | ||||
| ``seed.iso`` was previously created in directory ``/tmp/``. It's necessary to | ||||
| move it to ``/var/lib/vz/template/iso`` | ||||
| 
 | ||||
| .. cfgcmd:: mv /tmp/seed.iso /var/lib/vz/template/iso/ | ||||
| 
 | ||||
| On proxmox server: | ||||
| 
 | ||||
| .. code-block:: none | ||||
| 
 | ||||
|    ## Create VM, import disk and define boot order | ||||
|    qm create 555 --name vyos-1.3.0-cloudinit --memory 1024 --net0 virtio,bridge=vmbr0 | ||||
|    qm importdisk 555 vyos-1.3.0-cloud-init-10G-qemu.qcow2 local | ||||
|    qm set 555 --virtio0 local:555/vm-555-disk-0.raw | ||||
|    qm set 555 --boot order=virtio0 | ||||
|     | ||||
|    ## Import seed.iso for cloud init | ||||
|    qm set 555 --ide2 media=cdrom,file=local:iso/seed.iso | ||||
|     | ||||
|    ## Since this server has 1 nic, lets add network intefaces (vlan 25 and 26) | ||||
|    qm set 555 --net1 virtio,bridge=vmbr0,firewall=1,tag=25 | ||||
|    qm set 555 --net2 virtio,bridge=vmbr0,firewall=1,tag=26 | ||||
|     | ||||
| ----------------------------- | ||||
| Power on VM and verifications | ||||
| ----------------------------- | ||||
| 
 | ||||
| From cli or GUI, power on VM, and after it boots, verify configuration | ||||
| 
 | ||||
| 
 | ||||
| ---------- | ||||
| References | ||||
| ---------- | ||||
| 
 | ||||
| * VyOS `cloud-init-docs`_. | ||||
| 
 | ||||
| * Cloud-init `network-config-docs`_. | ||||
| 
 | ||||
| * Proxmox `Cloud-init-Support`_. | ||||
| 
 | ||||
| .. stop_vyoslinter | ||||
| 
 | ||||
| .. _network-config-docs: https://cloudinit.readthedocs.io/en/latest/topics/network-config.html | ||||
| .. _vyos-vm-images: https://github.com/vyos/vyos-vm-images | ||||
| .. _cloud-init-docs: https://docs.vyos.io/en/equuleus/automation/cloud-init.html?highlight=cloud-init#vyos-cloud-init | ||||
| .. _Cloud-init-Support: https://pve.proxmox.com/pve-docs/pve-admin-guide.html#qm_cloud_init | ||||
| 
 | ||||
| .. start_vyoslinter | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user