Creating Containers in Proxmox
Proxmox hypervisor also allows you to create containers which are lighter than virtual machines.
data:image/s3,"s3://crabby-images/9d6bb/9d6bb5429946277eb15cfae9ebdbc3eb104bdcd8" alt="Warp Terminal"
In the earlier chapters of the Proxmox series, you learned to install Proxmox and create new virtual machines in it.
Proxmox is different as it also allows you to create containers. As you may know, containers are more lightweight than virtual machines as they share the same kernel. Containers are virtualization at the operating system level, while virtual machines are virtualization at the hardware level.
Another advantage is that you can deploy tools and services using their container images.
In this tutorial, I will be showing you how to create an LXC container in ProxMox.
Creating a container in Proxmox
To start off, log in to your ProxMox web console and click on the "local" data store in the network. To the right of that you'll see an option called "CT Templates".
data:image/s3,"s3://crabby-images/e5c7c/e5c7cd20c62502e3115ddf2d7a9dc87b2b67a519" alt="Click on the local data store from the side panel and select the CT Templates"
Click on the "Templates" button, and a list of available templates will appear.
data:image/s3,"s3://crabby-images/59558/59558466173ac19c31c61356cd3ca28b4bd99c8b" alt="A list of available templates is displayed"
Go ahead and select the template you want to install. In my case, I'll be installing an Ubuntu 22.04 template. Click Download when you've selected the one you want. The download will proceed and will show TASK OK when completed.
data:image/s3,"s3://crabby-images/948e4/948e42641a35fe2b7399ac903e4d72a1192cf18f" alt="Downloading the selected template. Once completed, you will get a TASK OK message"
You now have an Ubuntu 22.04 template ready to use. It will be available in your templates as seen below.
data:image/s3,"s3://crabby-images/03857/038572201afc4e69d4c82c8396bb3a064e43ef22" alt="After download completed, you will now have an Ubuntu 22.04 template ready to use, and can be found listed on the window"
Click on "Create CT" and the LXC creation menu will appear as below.
data:image/s3,"s3://crabby-images/fc73d/fc73dbcfef5bc49c325222c1907bcabdfd6a2b5b" alt="Click on the Create CT button to get an LXC creation menu"
Enter a hostname (name of container) and create and confirm a password. In my case I called my container "test". Everything else can be left as is.
data:image/s3,"s3://crabby-images/f718e/f718efdf156741240bb18622f102faa907b2cd89" alt="Set hostname and enter password. You need to confirm the password too. Other fields can be left as is"
Click on the Template tab, and arrow down on "template". Notice your storage is "local", which means that the template is residing on the local disk in your server. You'll see your template that you downloaded earlier pop up. Click on it and click "next" to move on.
data:image/s3,"s3://crabby-images/0862c/0862c6b4994c4f7f859ec78b725e3cbd66c0d2a0" alt="On the Template tab, select Ubuntu, the one you downloaded, from the drop down list"
Enter the size of your virtual hard disk in GiB. I'm leaving mine at the default 8 gigs, but you can put whatever you want here, as long as you physically have that much storage to use on your host server/computer. Click "next" to move on.
data:image/s3,"s3://crabby-images/8db7c/8db7c77fb758746fe1bd58650c205dbd8fb89b42" alt="Set the virtual hard disk size to 8 GiB or whatever your system can safely afford"
Enter the number of CPU cores you want to assign to your container. I've assigned half of my available cores (4) here. Click "next".
data:image/s3,"s3://crabby-images/7913a/7913a6540ef21964a5aab36405ef9392036e3479" alt="On the CPU tab, set the number of CPU cores you can give. Here, it is given 4 cores"
Enter the amount of memory you wish to assign your container. Best practice is to assign half the amount of assigned memory as swap space.
data:image/s3,"s3://crabby-images/02d19/02d192b8dba09df1859245f53e898a8bcd6f2928" alt="Enter the amount of memory you wish to assign your container. A better practice is to assign half the amount of assigned memory as swap. Here, 512 MiB is given as memory and 256 Mib as Swap"
For network information, you can either allow DHCP to assign your container an IP address, or you can set up a static address in this section. I've decided to let DHCP handle it, as this is only a demonstration, but if this is a production server you may wish to consider assigning a static IP for convenience. Make sure to also enter your gateway (router) address in the appropriate section as well. IPV6 addressing can be set up in this section if required/desired.
data:image/s3,"s3://crabby-images/9d695/9d695f60cfe9127e06903a549fbe9605e2e905d9" alt="Set the values for IPv4, IPv6, gateway address etc."
If you have specific DNS servers that you want to use, enter them in this section, otherwise ProxMox will just use the settings of your host server.
data:image/s3,"s3://crabby-images/7dc6b/7dc6bbe104e7f3c9eb1a85add7154637ab5a94a1" alt="Enter values if you have some specific DNS Servers that you want to use. If not, ProxMox will use settings of your host server"
If everything looks good, go ahead and create the container after reviewing the settings you've just configured.
data:image/s3,"s3://crabby-images/72821/72821c4bc6834cadcf743fef13930e3fd44a3e1c" alt="Review the settings you have configured and press Finish if everything is OK"
The container will create itself, and will give you a TASK OK if everything went well.
data:image/s3,"s3://crabby-images/effd6/effd6e8550e2dd8c1d1c30e58c25e178a062de2a" alt="Container will be created and if everything went well, you will get a TASK OK message"
If you've clicked on "start after created" like I did, you'll notice that your container is now started and ready for use.
data:image/s3,"s3://crabby-images/51722/51722ea6591810076deb2ef18c6f40210003caa1" alt="On the overview page, set start after created"
Go ahead and click on it, and click the "console" tab. Press enter a few times, and a login prompt will appear. No installation needed, these are much simpler than regular virtual machines.
data:image/s3,"s3://crabby-images/77ac7/77ac713a5b69e559f28f9b345917ab32bfb42f5f" alt="System is ready to login, which can be done through the console tab on the right sidebar"
And that's all there is to it! Note that with virtual machines, it's possible to create Windows VMs, however you can only create Linux containers because they share a kernel.
Stay tuned for more Proxmox tutorials.
I'm an experienced System Administrator with a focus on transitioning into a Computer Systems Analyst role.