This morning at work I have been migrating our docker compose containers that currently run on an Ubuntu 22.04 Server VM onto individual Proxmox LXC containers running Ubuntu 22.04 so I thought that I would document it here so that I have a record of what I did and pass on the information as the containers seem to work way better running on LXC containers and they use way less resources than the Ubuntu 22.04 VM.
While I was playing around with the LXC containers I discovered that if you use a template you can speed up container roll out and it will also make it really easy to use Ansible to automate the roll out of new and existing containers going forwards which is a massive plus for me 🙂
Download the LXC Template
Before we can create the template we first need to have an Ubuntu 22.04 Proxmox LXC image downloaded on your server to boot from. To do this log into the Proxmox gui and click on the Proxmox server name:
data:image/s3,"s3://crabby-images/d03b9/d03b942154c594350cfd7c7f1fa7d3f0de7d8d6e" alt="Screenshot 2024 02 27 at 15.09.11 Create a Proxmox LXC container Template"
Click on Shell to open up the server command line:
data:image/s3,"s3://crabby-images/57bd4/57bd48fdb35423a827ab7e89d5ee86584ffc198e" alt="Screenshot 2024 02 27 at 15.10.08 Create a Proxmox LXC container Template"
We are going to use the pveam command line tool to fetch our image but first we need to update pveam to the latest version by running the following command:
pveam update
This will show the following when run successfully:
data:image/s3,"s3://crabby-images/7efac/7efac1ba64a5de71cb54ffc2f13fad4d94c49110" alt="Screenshot 2024 02 27 at 15.21.27 Create a Proxmox LXC container Template"
Next run the following command to see all the images that are available to download:
pveam available
This will show a long list of images that can be downloaded:
data:image/s3,"s3://crabby-images/6a426/6a42662957efd08fb6076b36dd23c07f8ce0caba" alt="Screenshot 2024 02 27 at 15.25.07 Create a Proxmox LXC container Template"
Scroll up and find the Ubuntu images and copy the name of the 22.04 image:
data:image/s3,"s3://crabby-images/4a597/4a5977ed051fbcf2d9f511babcf87e9dc5ca41da" alt="Screenshot 2024 02 27 at 15.24.20 Create a Proxmox LXC container Template"
Next run the following command to download the ubuntu image:
pveam download local ubuntu-22.04-standard_22.04-1_amd64.tar.zst
Wait for the image to download. It will not take very long as it is very small (129.82mb):
data:image/s3,"s3://crabby-images/cbc8e/cbc8ed596a5b851270b0e8df56cdf679539759db" alt="Screenshot 2024 02 27 at 15.27.01 Create a Proxmox LXC container Template"
This will have copied the new image to /var/lib/vz/template/cache/ and it will now show up in the Local disk, CT Templates in the gui:
data:image/s3,"s3://crabby-images/4bef7/4bef71ebeb6e3b2f1b2292eea4ade48c96e7d8bf" alt="Screenshot 2024 02 27 at 15.30.07 Create a Proxmox LXC container Template"
Create LXC VM
Before we can create a LXC container template we first need to create an LXC container using the Ubuntu 22.04 image that we have just downloaded using pveam.
To create the LXC Container click on the Create CT Button at the top right of the screen:
data:image/s3,"s3://crabby-images/c97fe/c97feb11f044bd7e2c1fa790ae93715513f850c1" alt="Screenshot 2024 02 27 at 15.41.24 Create a Proxmox LXC container Template"
Fill in the desired CT ID:, name of the LXC Container, Type in desired password in the 2 password Fields and if you want to use an ssh key to connect to the VM add that too:
data:image/s3,"s3://crabby-images/2f301/2f301836f508313dbb7679bc824e9e36a0992290" alt="Screenshot 2024 02 27 at 15.45.30 Create a Proxmox LXC container Template"
Click Next to save the changes and move to the next tab:
data:image/s3,"s3://crabby-images/f73fb/f73fba5b4bb73d191e3b2b45fcf3553107d43228" alt="Screenshot 2024 02 27 at 15.46.43 Create a Proxmox LXC container Template"
Click on the arrow and select the Ubuntu 22.04 image:
data:image/s3,"s3://crabby-images/1538c/1538c96f6e3364b8226c062e9ffa0ed9c7a438ae" alt="Screenshot 2024 02 27 at 15.48.17 Create a Proxmox LXC container Template"
Click next to move to the disks tab:
data:image/s3,"s3://crabby-images/9f975/9f975e273cd86dbe1583edd2d035a76445f683f5" alt="Screenshot 2024 02 27 at 15.49.56 Create a Proxmox LXC container Template"
Change the disk size if needed or leave as default 8GB is that is enough and click Next:
data:image/s3,"s3://crabby-images/59e84/59e84a21c8fdb8906a232ca972c999136ee0d3e3" alt="Screenshot 2024 02 27 at 15.50.29 Create a Proxmox LXC container Template"
Click next if you are ok with giving the container the default 1 cpu core, or change to the required number and click next again:
data:image/s3,"s3://crabby-images/6c9a1/6c9a1300cce90beb81f348e0824cfdf0e0e84121" alt="Screenshot 2024 02 27 at 15.51.48 Create a Proxmox LXC container Template"
Click Next to accept the default 512mb ram or change to the desired memory amount and click next:
data:image/s3,"s3://crabby-images/4fc8c/4fc8cca1ea2123d5800ef772d7bd64a0b2c88e00" alt="Screenshot 2024 02 27 at 15.53.21 Create a Proxmox LXC container Template"
Change the IPv4 setting from Static to DHCP so that it will get an ip address automatically when it boots as will the cloned LXC container when they boot then click Next:
data:image/s3,"s3://crabby-images/d20fb/d20fb4f7e0b1b8015fcf32247a8e30fc4912bc65" alt="Screenshot 2024 02 27 at 15.55.08 Create a Proxmox LXC container Template"
Add the desired dns server ip addresses to the fields and then click next:
data:image/s3,"s3://crabby-images/a1cf6/a1cf6c991c257cdd13684131bc3021a371b8fc74" alt="Screenshot 2024 02 27 at 15.56.58 Create a Proxmox LXC container Template"
Check that all the settings are correct and then click next to create the container:
data:image/s3,"s3://crabby-images/49b29/49b29c156655ac73b60869b3e7ce8ed4f21a6cbc" alt="Screenshot 2024 02 27 at 15.57.51 Create a Proxmox LXC container Template"
Proxmox will now create the container:
data:image/s3,"s3://crabby-images/115ed/115eda433e186b73ddddb329ed13ed212e221e91" alt="Screenshot 2024 02 27 at 15.58.29 Create a Proxmox LXC container Template"
Close the window when finished and the new container will now be in the container/vm list:
data:image/s3,"s3://crabby-images/2510b/2510bbf0a1aa30edabf76e3b51e83f4acd82cbd5" alt="Screenshot 2024 02 27 at 16.00.36 Create a Proxmox LXC container Template"
Click on the new Container name and select Console and click Start now to start the Container:
data:image/s3,"s3://crabby-images/45569/45569375e067d1aebfd88ecd41bdb29501b7e4e2" alt="Screenshot 2024 02 27 at 16.02.19 Create a Proxmox LXC container Template"
The container will now start (Almost immediately! Yah Containers!):
data:image/s3,"s3://crabby-images/bbf7b/bbf7bba62d01bdc9b94e509ec644e6da5e5dcc54" alt="Screenshot 2024 02 27 at 16.03.21 Create a Proxmox LXC container Template"
Log into the container with the user of root and the password setup during configuration:
data:image/s3,"s3://crabby-images/83e31/83e311645bf73fbe2775fbcf19553c6656b1f8eb" alt="Screenshot 2024 02 27 at 16.05.26 Create a Proxmox LXC container Template"
Configure the new container with whatever you need to install
One advntage of using LXC Containers over VM’s is that there is no need for the Proxmox Guest agent to be installed so that is one less thing that needs to be installed! Here is what I install for my base template:
Run the following command to update apt:
apt update
Once that has finished run the following command to update Ubuntu:
apt upgrade -y
I then install vim as it is my preferred text editor by running:
apt install vim
Type y and press enter to install vim:
data:image/s3,"s3://crabby-images/f6404/f6404ba7456232c6f3208a5929bc6be348bec020" alt="Screenshot 2024 02 27 at 16.15.18 Create a Proxmox LXC container Template"
Wait for vim to be installed.
Next I allow the root user to ssh using a password by running:
vim /etc/ssh/sshd_config
Find the line that contains PermitRootLogin prohibit-password:
data:image/s3,"s3://crabby-images/264d6/264d639058661981bac58726d73904ee9a7ea8c8" alt="Screenshot 2024 02 27 at 16.18.10 Create a Proxmox LXC container Template"
Change the line to PermitRootLogin yes
data:image/s3,"s3://crabby-images/e8065/e8065b5c60e5a5d0e007d56764eebbc748d4baa1" alt="Screenshot 2024 02 27 at 16.19.25 Create a Proxmox LXC container Template"
Save the file.
As most of my LXC containers will be used to run docker compose containers I install docker and docker compose using the instructions from THIS post.
That is all my Template has installed but feel free to add anything else you need on a standard container and then power off the VM. The easiest way to do this is to click the Shutdown button at the top of the console:
data:image/s3,"s3://crabby-images/a3645/a3645ed6d9382026e00485d39497d48a826113d9" alt="Screenshot 2024 02 27 at 16.26.51 Create a Proxmox LXC container Template"
Click Yes to confirm shutdown:
data:image/s3,"s3://crabby-images/0800c/0800c4a966ecfe6bee8ebb3ddd65ad8626d938c5" alt="Screenshot 2024 02 27 at 16.30.08 Create a Proxmox LXC container Template"
The container will now power off.
Convert the LXC container to a template
To convert you newly configured LXC container to a template to use to quickly create new containers from right click on the LXC container’s name in the left hand menu of the GUI:
data:image/s3,"s3://crabby-images/98dd0/98dd0dbd2f3bc53b3212d05e463ff9427d7c1d0b" alt="Screenshot 2024 02 27 at 16.33.54 Create a Proxmox LXC container Template"
Select Convert to template:
data:image/s3,"s3://crabby-images/c1a8d/c1a8dd54f1ce6fd6ed0d48a2857de94f168ebc2f" alt="Screenshot 2024 02 27 at 16.34.33 Create a Proxmox LXC container Template"
Click Yes to convert the LXC Container to a template:
data:image/s3,"s3://crabby-images/14262/14262e9731a3761ea549d36d9b9441ede831796d" alt="Screenshot 2024 02 27 at 16.36.18 Create a Proxmox LXC container Template"
The image to the left of the name will now change to indicate that it is now a template:
data:image/s3,"s3://crabby-images/8d777/8d777513933eb16ff6dabbd16f5cca37e41b5dd9" alt="Screenshot 2024 02 27 at 16.37.19 Create a Proxmox LXC container Template"
That is the end of the Ubuntu 22.04 LXC Container setup tutorial. You now have a ready to use template.