Homelab part 1: My Proxmox Setup

After several trials with virtual machines using nested virtualisation, I've managed to define the installation of my machines properly.

VersionDateComments
101/2024Post creation
1.101/2024Move from BTRFS to XFS, subnet to B class instead of C class, update screenshots, reformulations

Technical choices

After countless weeks, even months, of careful thought and testing (hello web colleagues and friends), I came up with a technical solution that fully met my requirements. This solution has been successfully deployed on multiple hosts, supporting substantial workloads. This type of architecture is also often favoured across the Atlantic by enthusiasts. The general idea of the homelab is to have a cluster of Proxmox machines and unified storage between them. Hyper-convergence is pushed to the maximum of available capacities. Here are the features:

  • Base OS : Debian 12.x
  • Hypervisor : Proxmox VE 8.x
  • System storage : boot via EFI, partitions LVM+XFS for system, home et tmp.
  • VM storage : Ceph. As I only have one hard disk, I want and need to use Ceph on the only disk available to me.
  • Network : subnet with /16 for everything. One VLAN is tagged for Ceph only (described below). For businesses, prefer at least a 10 Gbit/s network, with dedicated network cards and LAG.
💡
The configuration suggested here is functional and represents the bare minimum required to set up the Proxmox cluster with Ceph. However, it is important to note that Ceph performance could be impacted, mainly due to the use of a 1 Gbit network and the deployment of a single OSD per machine.

My process began with the installation of the official “netinst” ISO image of Debian 12.4. This step was essential to establish the foundation necessary for the subsequent installation of Proxmox. For this project, I have 4 identical machines, all Chuwi LarkBox X 2024s. Each machine is equipped with a 512 GB NVMe SSD and two network cards: an Intel 1 GE and a Realtek 2.5 GE.

The challenge was to get the entire system and Ceph to run on this drive alone. To do this, I undertook the following partitioning:

  • Partition 1 : EFI — 512 Mb, boot
  • Partition 2 : LVM “system” — 96 Gb
    • lv “root”, 48 Gb, mounted on /, XFS
    • lv “home”, 12 Gb, mounted on /home, EXT4
    • lv “tmp”, 8 Gb, mounted on /tmp, EXT4
    • lv “swap”, 8 Gb, for swap usage only.
  • Partition 3 : 350 Gb, reserved for Ceph OSD. It is important not to create this partition during the initial installation of Debian. I'll come back later to configure it when setting up the environment.

The root partition (/) will house the operating system, among other things. Given that Proxmox and Ceph generate a considerable volume of data (due to logs), I preferred to avoid any potential restrictions due to the limited number of inodes. Although an EXT4 partition may be sufficient for small home labs without reaching the limits, I opted for an early approach.

The /home and /tmp partitions will benefit from reinforced configurations to minimise the attack surface and limit abuse.

Installation and configuration of Proxmox and Ceph

Proxmox part

To install Proxmox, I strictly followed the instructions detailed in the article available at this address. All the steps described were scrupulously reproduced to obtain a functional, ready-to-use installation.

Once Proxmox is installed and operational, the network bridges are created in the “Network” section. I set up a dedicated bridge for each network card, as shown in the example below:

The network card “enp1s0” is dedicated to my LAN, and the network card “enp2s0” is dedicated only for Ceph. A tagged VLAN is created on my switch, and I created a “Linux VLAN” with the same VLAN ID. The bridge “vmbr15” will be used by VM to access to the CephFS storage.

Do this on each host to ensure a uniform configuration, which is crucial for the consistency of the infrastructure. It is imperative to guarantee identical NTP synchronization between hosts, as Ceph will not function correctly without this.

In addition, be sure to check and update the “hosts” file to reflect the IP address and name of each Proxmox host. Although the DNS server performs this operation, consider this input step as a backup, which could prove vital for the cohesion of the cluster.

At this point, you should be ready to create a cluster and connect your Proxmox hosts. I voluntarily skip the SSH configuration, key exchange and similar technical niceties. For the creation of a Proxmox cluster, I recommend that you watch the video made by my dad: