This application allows you to automate templates creation for Proxmox VE.
It provides a simple way to create templates for Proxmox VE by using a simple YAML file or command line arguments.
You can install the application by downloading the latest version from Releases page.
By default, application expects configuration file to be located at /etc/ptm/config.yaml
.
You can override:
- Configuration file location by using
--configuration-path
argument. (defaults to/etc/ptm
) - Configuration file name by using
--configuration-name
argument. (defaults toconfig
) - Configuration file extension by using
--configuration-extension
argument. (defaults toyaml
)
Below, you would be able to find examples of configuration file sections.
All examples are using YAML format.
Most of them are presented with the default values that application would use if no configuration is provided.
Downloader configuration is located under downloader
key.
Downloader is responsible for downloading and saving images from remote location.
downloader:
save_to: /etc/ptm/images
Keys:
save_to
- path to directory where downloaded images should be saved. (defaults to/etc/ptm/images
)
Base image configuration is located under base_image
key.
It is responsible for providing information on what type of image you want to download.
base_image:
distribution: ubuntu
release: jammy
minimal: true
architecture: amd64
format: img
Keys:
distribution
- distribution of the image. (defaults toubuntu
)release
- release of the image. (defaults tojammy
)minimal
- whether image should you want to download the "minimal" version of the image. (defaults totrue
)architecture
- architecture of the image. (defaults toamd64
)format
- format of the image. (defaults toimg
)
Extra packages configuration is located under extra_packages
key.
It is responsible for providing information on what extra packages should be installed on the image.
It is a list of strings, which are package names.
extra_packages: []
Repositories configuration is located under repositories
key.
It is responsible for providing information on what repositories should be added to the image.
repositories:
- name: docker
gpg: https://download.docker.com/linux/ubuntu/gpg
url: https://download.docker.com/linux/ubuntu
release: jammy
component: stable
key_name: docker-archive-keyring
Keys:
name
- name of the repository. (used to generate lists file name in/etc/apt/sources.list.d/
)gpg
- URL to GPG key file.url
- URL to repository.release
- release of the repository.component
- component of the repository.key_name
- name of the key file in/usr/share/keyrings/
. (extension is added automatically)
Qemu configuration is located under qemu
key.
It is responsible for providing information on what qemu options should be used when creating the template.
Most of the time, you would use this configuration to skip some of the configuration steps to speed up the process.
If any of the options are not provided, application would prompt you to provide them during the process.
If all of the options are provided, application would skip the configuration step and use provided values.
qemu:
identifier: 9000
name: ubuntu-cloudinit
image: /etc/ptm/images/ubuntu-21.10-minimal-amd64.img
resources:
cores: 2
memory: 2G
cpu_type: host
storage:
name: local-lvm
resize: 4G
network:
driver: virtio
bridge: vmbr0
Keys:
identifier
- identifier of the template.name
- name of the template.image
- path to the image file.resources
- resources configuration.cores
- number of cores.memory
- amount of memory.cpu_type
- type of CPU.
storage
- storage configuration.name
- name of the storage. (refers to the storage name in Proxmox VE, for example,local-lvm
)resize
- amount of disk space to allocate for the template. (used to resize the image file)
network
- network configuration.driver
- driver to use for the network interface.bridge
- bridge to use for the network interface.
Cloud-Init configuration is located under cloud_init
key.
It is responsible for providing information on what cloud-init configuration should be used when creating the template.
Most of the time, you would use this configuration to skip some of the configuration steps to speed up the process.
If any of the options are not provided, application would prompt you to provide them during the process.
If all of the options are provided, application would skip the configuration step and use provided values.
All of them are optional, but if enabled
is set to true
, application will "autoconfigure" IPv4 and IPv6 addresses. (DHCP)
cloud_init:
enabled: true
username: administrator
password: 12345678
ssh_authorized_keys:
- /root/.ssh/administrator.pub
- ssh-rsa AAAAB3NzaC1yc2EAAA
network:
ipv4:
auto_configure: true
ip: 127.0.0.10/24
gateway: 127.0.0.1
ipv6:
auto_configure: true
ip: ::1/128
gateway: ::1
Keys:
enabled
- whether cloud-init should be enabled.username
- username of the user that should be created.password
- password of the user that should be created.ssh_authorized_keys
- list of paths to SSH public keys that should be added to the user.- You can provide keys as a string.
- You can provide keys as a path to a file.
network
- network configuration.ipv4
- IPv4 configuration.auto_configure
- whether IPv4 should be autoconfigured. (manual settings forip
andgateway
will be ignored if set totrue
)ip
- IPv4 address.gateway
- IPv4 gateway.
ipv6
- IPv6 configuration.auto_configure
- whether IPv6 should be autoconfigured. (manual settings forip
andgateway
will be ignored if set totrue
)ip
- IPv6 address.gateway
- IPv6 gateway.
Unattended Upgrades configuration is located under unattended_upgrades
key.
It is responsible for providing information on what unattended upgrades configuration should be used when customizing the image.
If not present, application will not try to setup unattended upgrades.
unattended_upgrades:
enabled: true
whitelist:
- "${distro_id}:${distro_codename}"
- "${distro_id}:${distro_codename}-security"
- "${distro_id}ESMApps:${distro_codename}-apps-security"
- "${distro_id}ESM:${distro_codename}-infra-security"
- "${distro_id}:${distro_codename}-updates"
- "Docker:${distro_codename}"
- "InfluxDB:stable"
blacklist: []
dev_release: "auto"
fix_interrupted: true
minimal_steps: true
install_on_shutdown: false
remove_unused_kernel: true
remove_unused_dependencies: true
remove_unused_auto_depend: true
automatic_reboot: true
automatic_reboot_with_users: true
automatic_reboot_time: "04:00"
Keys:
enabled
- whether unattended upgrades should be enabled.whitelist
- list of origins that should be whitelisted.blacklist
- list of packages that should be blacklisted.dev_release
- whether unattended upgrades should use development release.fix_interrupted
- whether unattended upgrades should fix interrupted upgrades.minimal_steps
- whether unattended upgrades should use minimal steps.install_on_shutdown
- whether unattended upgrades should install updates on shutdown.remove_unused_kernel
- whether unattended upgrades should remove unused kernel.remove_unused_dependencies
- whether unattended upgrades should remove unused dependencies.remove_unused_auto_depend
- whether unattended upgrades should remove unused auto dependencies.automatic_reboot
- whether system should automatically reboot.automatic_reboot_with_users
- whether system should automatically reboot with users.automatic_reboot_time
- time when system should automatically reboot.
Although application does not require you to have any configuration, it is still required to have configuration file created.
This section describes how to use the application.
The following commands are available:
version
- displays application version.help
- displays help message.customize
- allows user to customize the image.make
- allows user to create the template.
This command allows you to customize the image.
It will ask you for all the required information and then it will download (if missing) and customize the image.
You can use --help
argument to display help message for this command.
This command allows you to create the template.
It will ask you for all the required information and then it will create the template.
You can use --help
argument to display help message for this command.
In prompt flow mode (assuming you have not provided flags or configuration options to make configuration valid), application will ask you for all the required information.
It will guide you through the process and ask you for all the required information.
Upon completion, it will create the template.
In configuration flow mode (assuming you have provided complete configuration - this includes qemu
and cloud_init
configuration), application will skip the prompt flow and use provided configuration.
It will create the template using provided configuration.
In flags flow mode (assuming you have provided flags), application will skip the prompt flow and use provided flags.
The caveat of this flow is that you must provide almost all of the flags.
It will create the template using provided flags.
It is ideal for automation purposes.
Here is the list of flags that you must provide:
--identifier
- Identifier of template (required)--name
- Name of the template (required)--cores
- Number of cpu cores (required)--cpu-type
- Desired cpu type (host / kvm64 / etc) (required)--memory
- Amount of memory (example: 1024 / 1024M / 1G) (required)--storage
- Disk storage (local-lvm / local / etc) (required)--image
- Path to the image (/etc/ptm/images/image.qcow2) (required)--mage-new-size
- Size to which the image should be resized (example: 4G) (optional)--network-driver
- Network driver (virtio / e1000 / etc) (required)--network-bridge
- Network bridge (vmbr0 / vmbr1 / etc) (required)--ci-username
- Username for cloud-init (optional)--ci-password
- Password for cloud-init (optional)--ci-ssh-keys
- Comma-separated list of SSH keys for cloud-init (optional)--ci-ipv4-auto
- Automatically configure IPv4 for cloud-init--ci-ipv6-auto
- Automatically configure IPv6 for cloud-init--ci-ipv4-address
- Manually set IPv4 address for cloud-init (example: 10.10.10.10/24) (not required when--ci-ipv4-auto
flag is used)--ci-ipv6-address
- Manually set IPv6 address for cloud-init (example: 2001:db8::1/64) (not required when--ci-ipv4-auto
flag is used)--ci-ipv4-gateway
- Manually set IPv4 gateway for cloud-init (example: 10.10.10.1) (not required when--ci-ipv6-auto
flag is used)--ci-ipv6-gateway
- Manually set IPv6 gateway for cloud-init (example: 2001:db8::1) (not required when--ci-ipv6-auto
flag is used)