1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
#!/bin/bash
set -x
#Create template
#args:
# vm_id
# vm_name
# file name in the current directory
function create_template() {
#Print all of the configuration
echo "Creating template $2 ($1)"
if [ $(qm list | grep $1 | wc -l) -eq 1 ]
then
echo "VM already exist"
echo "Will delete the vm"
qm destroy $1
if [ $? -eq 0 ]
then
echo "delete vm successfully!"
else
echo "delete failed!"
fi
else
echo "VM didn't exist"
echo "will create it"
fi
#Create new VM
#Feel free to change any of these to your liking
qm create $1 --name $2 --ostype l26
#Set networking to default bridge
qm set $1 --net0 virtio,bridge=vmbr0
#Set display to serial
qm set $1 --serial0 socket --vga serial0
#Set memory, cpu, type defaults
#If you are in a cluster, you might need to change cpu type
qm set $1 --memory 1024 --cores 4 --cpu host
#Set boot device to new file
qm set $1 --scsi0 ${storage}:0,import-from="$(pwd)/$3",discard=on
#Set scsi hardware as default boot disk using virtio scsi single
qm set $1 --boot order=scsi0 --scsihw virtio-scsi-single
#Enable Qemu guest agent in case the guest has it available
qm set $1 --agent enabled=1,fstrim_cloned_disks=1
#Add cloud-init device
qm set $1 --ide2 ${storage}:cloudinit
#Set CI ip config
#IP6 = auto means SLAAC (a reliable default with no bad effects on non-IPv6 networks)
#IP = DHCP means what it says, so leave that out entirely on non-IPv4 networks to avoid DHCP delays
qm set $1 --ipconfig0 "ip6=auto,ip=dhcp"
#Import the ssh keyfile
qm set $1 --sshkeys ${ssh_keyfile}
#If you want to do password-based auth instaed
#Then use this option and comment out the line above
#qm set $1 --cipassword password
#Add the user
qm set $1 --ciuser ${username}
#Resize the disk to 8G, a reasonable minimum. You can expand it more later.
#If the disk is already bigger than 8G, this will fail, and that is okay.
#qm disk resize $1 scsi0 8G
#Convert raw disk to qcow2
VM_FOLDER="/var/lib/vz/images"
qemu-img convert -f raw $VM_FOLDER/$1/vm-$1-disk-0.raw -O qcow2 $VM_FOLDER/$1/vm-$1-disk-0.qcow2
rm -rf $VM_FOLDER/$1/vm-$1-disk-0.raw
sed -i 's/.raw/.qcow2/g' /etc/pve/qemu-server/$1.conf
#Make it a template
qm template $1
#Remove file when done
rm $3
}
#Path to your ssh authorized_keys file
#Alternatively, use /etc/pve/priv/authorized_keys if you are already authorized
#on the Proxmox system
export ssh_keyfile=/root/id_rsa.pub
#Username to create on VM template
export username=echowings
#Name of your storage
export storage=local
export ID="9001"
export TEMPLATE_VM_NAME="template-vyos-1.3.5"
export VYOS_QEMU_IMAGE="vyos-1.3.5-amd64.qcow2"
export VM_IMAGE_FOLDER="/var/lib/vz/template"
export VM_DOWNLOAD_URL="https://xxxxx.xxxx.xxx/vyos-1.3.5-amd64.qcow2"
tee $ssh_keyfile << "EOF"
ssh-rsa MODIFY_TO_YOUR_SSH.PUB
EOF
ls -al $VM_IMAGE_FOLDER/$VYOS_QEMU_IMAGE
if [ ! -f $VM_IMAGE_FOLDER/$VYOS_QEMU_IMAGE ]
then
wget $VM_DOWNLOAD_URL -O $VM_IMAGE_FOLDER/$VYOS_QEMU_IMAGE
fi
cd $VM_IMAGE_FOLDER
create_template $ID $TEMPLATE_VM_NAME $VYOS_QEMU_IMAGE
|