Proxmox Storage Configuration for Beginners

Proxmox storage configuration for beginners

Proxmox is gaining steam as the leading open-source hypervisor. It is already the “home lab darling” among the community and it is gaining traction in the enterprise as well. One of the first things you will want to do with your Proxmox installation is configure your storage for virtual machines and containers. Let’s look at Proxmox storage configuration for beginners and see how you can get started.

Proxmox resources that need storage

What types of objects in Proxmox need storage locations and what are those different types?

  • ISO images โ€“ disk images for installing OS’es
  • Container storage โ€“ LXC containers storage
  • Virtual machine storage โ€“ virtual machine disk storage
  • Container templates โ€“ LXC container template storage
  • Directories โ€“ files
  • Proxmox backup โ€“ Proxmox Backup Server storage for storing backups of your virtual resources

Proxmox storage options

Like most hypervisors, Proxmox allows you to configure many different types of storage for your virtual machine environment. These include the following:

  • Local storage
  • Shared storage including network storage
  • Hyper-converged storage (HCI) with Ceph

We will look at each of these and see their strengths and weaknesses and why you might choose one over the other.

Local storage

The Local storage configuration is the first type of storage that you will likely setup when you start playing around with Proxmox in the home lab or even looking at it for production. With local storage, it is just that, local to the server. It means generally a local disk attached to your Proxmox host.

Local storage can be extremely fast thanks to modern NVMe storage and this is easy to set up. In fact, you can throw a couple of NVMe drives in your Proxmox host and have extremely fast VM storage for use in your environment. If you want to provision more disks, you can add more disks to Proxmox.

Nvme storage for proxmox
Nvme storage for proxmox

I have used many mini PCs with Proxmox installed and NVMe storage, and they are incredibly fast, running lots of VMs and containers without issues. With NVMe storage, the RAM is usually the limiting factor in most cases.

The local storage can also be set up as โ€œjust a bunch of disksโ€ (JBOD), or it can use some type of RAID configuration that protects your data if a drive fails. RAID5 and RAID6 are both common and provide this kind of redundancy.

Once Proxmox is installed, whether you are using one disk, two disks, or more, it will automatically create a default storage pool, so youโ€™ll have storage for your VMs right away.

How to add NVMe storage to your Proxmox server

If you want to see how to add NVMe storage to your Proxmox server, take a look at my how to write-up here: Proxmox add disk storage space โ€“ NVMe drive. This will walk you through the commands of how to add an NVMe drive to your server and provision it as storage.

Shared storage

The concept of shared storage is well-known in enterprise environments and provides benefits like Proxmox server clusters, live migration of virtual machines, high availability, and failover capabilities.

Shared storage is accessible to all the Proxmox hosts in a Proxmox VE cluster. Since each host can see and connect to the same storage, they all have equal access to the virtual machine and container storage. This setup means that if one host fails, the other servers can take over the VMs and containers, restarting them to bring them back online.

Below is a look at the Terramaster F8 SSD Plus that I recently reviewed here: Terramaster F8 SSD Plus Review: All Flash NAS with NVMe. Devices like this can be used to set up fast and easy-to-share iSCSI storage between multiple Proxmox servers.

Terramaster f8 ssd plus
Terramaster f8 ssd plus

You can use shared storage technologies like iSCSI, which is a block storage protocol. iSCSI shared storage works well because it lets you use your existing Ethernet network equipment as the underlying hardware. You can even run it on the same networking gear by separating it with a different VLAN.

Read my article on how to attach your Proxmox VE Server to iSCSI storage:

Hyper-converged storage (HCI) with Ceph

Thereโ€™s a third option that works well for organizations wanting to avoid the expense of storage area network (SAN) or NAS devices. HCI takes local storage and pools it across hypervisor nodes, presenting it as a single storage pool.

Ceph storage
Ceph storage

Parity information is replicated between the different Proxmox hypervisor hosts so that if you have a failure of an entire node, your data is still intact. Most of these systems use some type of object storage to work.

Ceph configuration in proxmox
Ceph configuration in proxmox

Learn how to setup Proxmox Ceph storage with my YouTube video below or the written blog here:

How to setup storage configuration in Proxmox Server

Configuring your storage setup in Proxmox Server involves several details, like choosing the storage type, setting the storage ID, and defining the content types. You can configure it using either the Proxmox web interface or the command line, but most people will likely handle the majority of their storage setup through the web interface.

You can also see the existing storage configuration located in the following file:

/etc/pve/storage.cfg
Viewing the etc pve storage cfg file
Viewing the etc pve storage cfg file

Thin provisioning

Thin provisioning is a technique that lets you over-provision storage. For instance, you can configure 100 gigs of storage to a virtual machine, but the storage system only uses the amount of space the VM actually needs. So if the operating system only uses 25 gigs, thatโ€™s all the storage that will be consumed.

Thin provisioning is commonly used in modern storage systems because it allows for efficient space allocation and better use of storage resources, especially with expensive flash production storage. Itโ€™s supported by many storage types, including LVM thin pools and ZFS.

Viewing storage configuration

Where do you see your Proxmox configured storage? You can see the storage that is configured in your Proxmox environment, by clicking on the Proxmox Datacenter > Storage:

Below you can see the Proxmox node has local, local lvm, and ZFS storage.

Viewing the storage configuration under the proxmox datacenter view
Viewing the storage configuration under the proxmox datacenter view

Also, in addition to the datacenter view, you can look at the local Proxmox server itself as well to see its configuration.

Viewing the disks view of the proxmox node
Viewing the disks view of the proxmox node
  • LVM thin pool configuration can be done using the Proxmox web interface or command line.
  • LVM thin pool configuration โ€“ requires a LVM volume group or volume groups and logical volume.

Proxmox storage โ€“ learning progression

Note the progression below:

  1. If youโ€™re just starting out with Proxmox, I recommend sticking with local storage first. Local storage will help you get comfortable with managing and administering Proxmox while still giving you the storage functionality you need. NVMe drives are very affordable now, so you can set up a simple mini PC with an NVMe drive, install Proxmox, and have a highly capable home lab server.
  2. Once youโ€™re ready to explore high availability, youโ€™ll need to transition to shared storage. If you have a NAS that supports NFS or iSCSI, you can use it to set up shared storage between two or more Proxmox servers. Both servers will connect to the shared storage and can run virtual machines directly from it. If one host fails, the other can take over the VMs from the failed host and start them back up.
  3. Delving into HCI storage is another option that lets you use locally attached disks in your Proxmox hosts and combine them into a single logical storage pool. HCI is very popular with businesses these days since it removes the need for expensive SAN arrays. However, Ceph, which is used in Proxmox for HCI, has its own requirements. Thatโ€™s why I recommend leaving HCI as the last step for beginners, so you can get familiar with other Proxmox features first.

Best practices to remember

  • Use a consistent naming convention for storage configurations.
  • Use storage groups to organize storage configurations.
  • Regularly back up storage configurations.

Wrapping up

Proxmox storage configuration is fairly simple for beginners with many different options for storing virtual machines and containers. You can start with local storage to get familiar with the platform, then move on to shared storage to experiment with Proxmox clustering, high availability, and live migration. If youโ€™re working with three or more Proxmox hosts, you can explore Ceph storage for HCI setups. This lets you share internal storage across your hosts without needing a SAN or NAS for disk space.

About The Author

0 0 votes
Article Rating
Subscribe
Notify of
guest

This site uses Akismet to reduce spam. Learn how your comment data is processed.

4 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
Karol

I like your posts very much. I start my day with them. I started the proxmox adventure for the purpose of escaping from VMware. I use storage array with VMware and so decided to do with proxmox as well – it seems to work, but at the expense of snapshots. I hope they will solve this problem in the future.

Jay Ashworth

Hey!

So, did you realize that you don’t actually “step through Proxmox storage configuration for beginners” in this piece? You tell me what you’re going to tell me, but you don’t seem to actually tell me that.

If this was just a pitch to a video, sorry, but I’m not looking for a video right now; it will take me way too long to learn that you’re not going to teach me the thing I need to know, that way.