Need help installing Proxmox with automatic decryption and multiple drives

needzfshlp

New Member
Aug 14, 2023
7
4
3
I'm trying to install Proxmox on a server that is going to be running Home Assistant, a security camera NVR setup and other sensitive data, I need to have the drives be encrypted with automatic decryption of drives so the VMs can automatically resume after a power failure.

# My desired setup:

* 2 Sata SSDs boot drives in a ZFS mirror
* 1 NVME SSD for L2ARC and VM storage
* 3 HDDs in a RAIDz1 for backups and general large storage
* 1 (maybe more added later) HDD for Camera NVR VM.

I'd prefer every drive encrypted with native ZFS encryption automatically decrypted by either TPM 2.0 or manually by a passphrase if needed as a backup.

# Guide I found:

I found a general guide on how to do something similar but it honestly went over my head (I'm still learning) and didn't include much information about additional drives: Proxmox with Secure Boot and Native ZFS Encryption


If someone could adapt that post into a more noob friendly guide for the latest Proxmox version, with directions for decryption of multiple drives, that would be amazing and I'm sure it would make an *excellent* addition to the Proxmox wiki ;)

# My 2nd preferred setup:

* 2 Sata SSDs boot drives in a ZFS mirror with LUKS encryption and automatic decryption with clevis.
* All other drives encrypted using ZFS native encryption with ZFS key (keys?) stored on LUKS boot drive partition.


With this arrangement, every drive could be encrypted at rest and decrypted on boot with native ZFS encryption on most drives but has the downsides of using LUKS on ZFS for the boot drives.


Is storing the ZFS keys in a LUKS partition insecure in some way? Would this result in undecryptable drives if something happened to ZFS keys on the boot drive or can they be also decrypted with a passphrase as a backup?


As it stands right now, I'm really stuck trying to figure this out so any help or well written guides are heavily appreciated. Thanks for reading!
 
I found a general guide on how to do something similar but it honestly went over my head (I'm still learning) and didn't include much information about additional drives: Proxmox with Secure Boot and Native ZFS Encryption
Additional drives aren't a problem when you work with keyfiles. You of cause then need a secure location (like an encrypted root partition) to store those keyfiles. See for example here: https://forum.proxmox.com/threads/f...s-using-proxmox-installer.127512/#post-557808

Would this result in undecryptable drives if something happened to ZFS keys on the boot drive or can they be also decrypted with a passphrase as a backup?
A keyfile is just a bunch of characters. Once the keyfile is lost, you won't be able to unlock your disks. So back them up using a password manager, print them out and put them in a safe or whatever.
 
I need to have the drives be encrypted with automatic decryption of drives so the VMs can automatically resume after a power failure.
For what use case are you encrypting the drives if you store the key on the drives itself? If someone stole your machine, there is no protection at all.

We use LUKS and ZFS native encryption in all our non-local servers (e.g. hosting and housing) and decrypt via nagios/icinga monitoring after detecting a reboot. A simple check run remotly that checks if mounted otherwise decrypt using the remotely provided key. With this setup, the machine requires remote decryption, but it is the only way I know to secure it properly.
 
For what use case are you encrypting the drives if you store the key on the drives itself? If someone stole your machine, there is no protection at all.

So traditionally the keys are stored in the TPM on the CPU. I'm having a hard time setting up native ZFS encryption where the keys are stored on the TPM. The second scenario that I described places the native ZFS encryption keys for the additional non-boot drives on an encrypted drive using LUKS on the boot drive which can be unlocked via the TPM. That is something I can do, but running ZFS on LUKS has additional downsides and is not preferable to native ZFS encryption. If someone stole the machine, it is protected by the login prompt. A metaphorical comparison could be made to a laptop that has full disk encryption but is stolen while it is powered on. The person who stole the laptop wouldn't be able to access the data because the laptop still has a login prompt of some kind.

So imagine a scenario where the power goes out, even just for a small amount of time. The uninterruptible power supply connected to the server allows for clean unmounting of the filesystems and then shuts the server off. The server then comes back on when power is detected from the grid again. If an encrypted drive doesn’t have automatic decryption and requires a passphrase before boot, the services that I’m self hosting aren’t running. I’m wanting to run home assistant and a security camera NVR so that could mean that I’m stumbling around in the dark tripping over things to get to the server to type in a passphrase because the lights didn't power on, or there could be a robbery and I now have no evidence of who the culprit might be because the server didn't send the pictures of someone breaking in to my phone and external backup source.


Having the drives automatically decrypt in a safe manner helps ensure higher availability (without me spending a small fortune in additional hardware costs because you can usually throw money at a problem to fix it), while still offering data protection in the event of a robbery.


The alternative to automatically decrypting drives while ensuring my services work after power failure is to not encrypt the drives at all.
 
Additional drives aren't a problem when you work with keyfiles. You of cause then need a secure location (like an encrypted root partition) to store those keyfiles. See for example here: https://forum.proxmox.com/threads/f...s-using-proxmox-installer.127512/#post-557808


A keyfile is just a bunch of characters. Once the keyfile is lost, you won't be able to unlock your disks. So back them up using a password manager, print them out and put them in a safe or whatever.

I know normally when setting up automatic decryption using keys stored on the TPM of a LUKS install without using native ZFS encryption, you can specify that the drive can be decrypted with multiple sources like both a keyfile stored on the TPM or a passphrase. The drive would get automatically decrypted using the keys stored on the TPM, but you could still decrypt the drive using a passphrase (stored in a secure location) as a backup if the drives had to be moved to a different computer, or if the TPM fails, or some other scenerio where you couldn't use the keys stored on the TPM. Does native ZFS encryption allow for using multiple key sources to unlock native ZFS encryption? I'm having a hard time setting up native ZFS encryption where the keys are stored on the TPM. The second scenario that I described places the native ZFS encryption keys for the additional non-boot drives on an encrypted drive using LUKS on the boot drive which can be unlocked via the TPM. That is something I can do, but running ZFS on LUKS has additional downsides and is not preferable to native ZFS encryption.
 
Having the drives automatically decrypt in a safe manner helps ensure higher availability (without me spending a small fortune in additional hardware costs because you can usually throw money at a problem to fix it), while still offering data protection in the event of a robbery.
umm... how is it providing data protection in the event of a robbery? the system will decrypt at boot; all that is necessary to get at the data is physical possession.
 
umm... how is it providing data protection in the event of a robbery? the system will decrypt at boot; all that is necessary to get at the data is physical possession.
My threat model is not state level actors or master hackers. In the event of a robbery, the most likely thing to happen is the server is sold by some crackhead on an online local marketplace, or just the OS wiped and replaced with Windows.

But lets assume someone stole the server with the intention of accessing the data in another spot...

Secure boot uses the TPM with my custom keys ensures integrity of the boot files so they can't be tampered with. My motherboard UEFI is password protected. If someone clears the password by resetting the UEFI, the custom TPM keys are cleared. After boot, the encryption keys enter RAM. My motherboard UEFI supports memory encryption making reading the encryption keys in RAM significantly more difficult to get at the keys. When the system is booted, it drops to a login shell. The attacker should only have access to a login shell that he doesn't know the password to. In summary, the attacker can't tamper with any of the boot process because of the TPM and Secure Boot, can't tamper with the UEFI because it is password protected, can't clear the UEFI to remove the password without clearing the TPM keys, can't extract the keys from RAM because of memory encryption, and can't do anything past a login shell they don't know the password to. This is very similar how Bitlocker on Windows works.


Please explain how to get at the data on the drive. Keep in mind that my threat model is NOT state level actors.
 
Last edited:
  • Like
Reactions: alexskysilk
I’m wanting to run home assistant and a security camera NVR so that could mean that I’m stumbling around in the dark tripping over things to get to the server to type in a passphrase because the lights didn't power on, or there could be a robbery and I now have no evidence of who the culprit might be because the server didn't send the pictures of someone breaking in to my phone and external backup source.
Why you then don't use a UPS so the server would continue running in case of a power failure? This is how you usually do it. Especially when running security cameras which should continue recording in case someone cuts the electricity line.
 
Last edited:
  • Like
Reactions: Docop2
Why you then don't use a UPS so the server would continue running in case of a power failure? This is how you usually do it. Especially when running security cameras which should continue recording in case someone cuts the electricity line.
You quoted me in your post here, but then conveniently left out the beginning of the paragraph you quoted which stated:

"So imagine a scenario where the power goes out, even just for a small amount of time. The uninterruptible power supply connected to the server allows for clean unmounting of the filesystems and then shuts the server off. The server then comes back on when power is detected from the grid again."


I have an uninterruptible power supply, but its small and mainly for safe shutdowns. It's not currently in the budget for a larger one.

This is my first post in this forum, I've done the best that I can to try to be informed as I can about proxmox before posting here and I know I'm still learning. I came here hoping to get some friendly advice with my technical issue from a welcoming community. A place where I could be humble and admit that I don't know how to do this. I've instead had multiple people argue about the way I'm trying to set this up as if the very question I'm asking is wrong.

I would appreciate if we could instead return to the original focus of the discussion, that being installing proxmox with automatic disk decryption using a TPM with native zfs encryption.
 
  • Like
Reactions: BeyondEvil
The person who stole the laptop wouldn't be able to access the data because the laptop still has a login prompt of some kind.
Thank you for the long explanation, but this is the crucial part: This may be true for windows, due to a lack of knowledge, but in Linux, there is nothing restricting this as long as you can inject whatever you want into the boot process. The TPM is used to decrypt your disks and this can be used from any Linux. All current implementations I saw get the key from the TPM on boot and use them to decrypt LUKS. As an adversary, you just boot your own linux environment, load the initramfs, which is unencrypted and inspect it. You then find the crypttab and decode what was done, reverse engineer it and load the LUKS key - do exactly that what would have been done by the OS/initram and voila ... decrypted. This is fine for securing the disk, but if your whole machine is stolen, it does not offer any additional security. If you also want to secure against such an attack, please read this, which summarizes it pretty well.
 
  • Like
Reactions: Johannes S
...and now we also know how to sniff the key while the OS / Windows is booting:

https://www.youtube.com/watch?v=wTl4vEednkQ

In addition to the video and sadly not mentioned there, for those TPM chips exist premade clamps that attach to the chip itself in order to have a very easy method to sniff it. I have a bunch of them for inplace flashing firmware, e.g. SOP-16 clamp.
 
  • Like
Reactions: Johannes S
I also remembered this discussion when watching that video some days ago but wasn't able to find this thread. :D
 
...and now we also know how to sniff the key while the OS / Windows is booting:

https://www.youtube.com/watch?v=wTl4vEednkQ

In addition to the video and sadly not mentioned there, for those TPM chips exist premade clamps that attach to the chip itself in order to have a very easy method to sniff it. I have a bunch of them for inplace flashing firmware, e.g. SOP-16 clamp.

Ok, you have been incredibly condescending with your replies without understanding my use case for this at all.

Let me break this down for you very clearly @LnxBil @Dunuin

1. As I stated in the beginning, my threat model is NOT state level actors. It is also not law enforcement officers, nor professional hackers. It is for people breaking into my house, stealing the computer and accessing security camera footage. People hooking up clamps to read the data off of a TPM chip is not in my list of concerns because i suspect that the cross section of people who break and enter into houses and people who know how to read the data off of a TPM chip is very small.

2. I understand that if someone has physical access to the hardware, it is a matter of time before someone can break into the system somehow. This is why data centers have higher security to prevent access BUT there is a reason why TPM based solutions are used. Another comment I read somewhere summed it up nicely "Generally you don’t want to immediately throw your hands in the air and give up just because a hacker has physical access. If you approach it that way, encrypting a drive would be pointless but it’s widely considered worth doing."

3. The video you linked showing the TPM chip being compromised only works in situations where a separate TPM chip is being used. A lot of modern systems use a TPM inside the CPU for exactly this reason.

Please explain to me how someone could exploit the following:
A proxmox server has full disk encryption unlocked by TPM on the CPU with a UPS that allows for clean unmounting of drives, secure boot enabled and a password protected secured bootloader. It runs an NVR to record the data from security cameras. When power is removed from the server, the UPS tells the server to shutdown the computer to cleanly unmount the drives to prevent physical data loss. Someone trying to access the data on the computer can't just take the drives out and access the data because they're encrypted. They can't just boot into a different OS or modify the boot process because of a password protected UEFI and secureboot. They can't remove the CMOS battery to attempt to remove the password from the UEFI because that would remove the user enrolled keys for both secure boot and the TPM. They can't just hook up some clips to the TPM because it is directly on the CPU. They can't just login to the server directly because it just boots into a password protected login prompt nor can they login from another computer through the network unless there is some kind of zero day ssh exploit.


4. Despite me explaining both my threat model and my use case, the forum members here keep going on and on about how this can be exploited and isn't secure, etc. as if ultimate security against every possible thing outside of my threat model is the only thing worth doing. Ultimate security isn't the point. The point is reasonable security. If the power goes out for a couple of minutes while I'm at work, my wife and 2 year old son do not (and shouldn't) know or be expected to a really long diceware password into a physical keyboard to unlock the proxmox server to access my self hosted services like Home Assistant.

If the TPM doesn't automatically unlock the disks, the only other alternative is NOT have disk encryption at all, which is what I have been forced to do the past several months.

Is that more secure than using the TPM to unlock the disks, @LnxBil & @Dunuin ?

It's clear that some forum members here want to attack my posts instead of just admitting that they don't know how to do use the TPM in this way.

This is my first post in this forum, I've done the best that I can to try to be informed as I can about Proxmox before posting here and I know I'm still learning. I came here hoping to get some friendly advice with my technical issue from a welcoming community. A place where I could be humble and admit that I don't know how to do this. I've instead had multiple people argue about the way I'm trying to set this up as if the very question I'm asking is wrong. I was able to admit my own insecurities about my lack of knowledge in this subject, that's why I came to this forum, but it has just been response after response of criticism without any help or direction with the issue that myself and multiple others have had.
 
  • Like
Reactions: BeyondEvil
Did you ever get this solved? @needzfshlp

I'm in a similar situation, albeit slightly less complicated as my Proxmox bootdrive is not ZFS but LVM. I'm looking to store the keyfile on there, but for obvious reasons want it encrypted.

Another approach I've been looking at is using Mandos and have the Mandos server running on a Pi.
 
  • Like
Reactions: needzfshlp
Did you ever get this solved? @needzfshlp

I'm in a similar situation, albeit slightly less complicated as my Proxmox bootdrive is not ZFS but LVM. I'm looking to store the keyfile on there, but for obvious reasons want it encrypted.

Another approach I've been looking at is using Mandos and have the Mandos server running on a Pi.
No. I was forced to run Proxmox with unencrypted drives. That seems to be implied by the moderators of this forum to be a more secure configuration than that having the drives be automatically unlocked with the TPM because the TPM might have some vulnerabilities that are unlikely to be exploited in my use case anyways. Yeah, wrap your head around them thinking that because the TPM might have a theoretical exploit that my better option would be to leave it in a configuration that would be the same result as if it were already exploited. Really makes you question what they're even thinking.

Here is what I would suggest to anyone reading this at a future date

Switch to Fedora CoreOS rebased to the hardened variant SecureBlue which supports both ZFS filesystems as well as unlocking with TPM (because who would ever even want that!?) Manage it all with Cockpit and cockpit extensions.

Code:
# Rebase to Secureblue

# Before rebasing to Secureblue, zincati.service must be disabled
systemctl disable zincati.service; systemctl stop zincati.service

# Determine which is the best Secureblue image for your use case. I chose one for myself.

# Rebase to the unsigned image, to get the proper signing keys and policies installed:
rpm-ostree rebase ostree-unverified-registry:ghcr.io/secureblue/securecore-zfs-main-userns-hardened:latest

# Reboot to complete rebase
systemctl reboot

# Rebase to signed image
rpm-ostree rebase ostree-image-signed:docker://ghcr.io/secureblue/securecore-zfs-main-userns-hardened:latest

# Reboot to complete installation
systemctl reboot


# Install Cockpit and Cockpit extensions
rpm-ostree install cockpit-system cockpit-ostree cockpit-podman cockpit-storaged cockpit-networkmanager cockpit-machines cockpit-sosreport cockpit-files cockpit-zfs cockpit-sensors cockpit-tailscale

#Reboot
systemctl reboot

# Enable Cockpit webserver login

# Enable password based SSH logins
echo 'PasswordAuthentication yes' | sudo tee /etc/ssh/sshd_config.d/02-enable-passwords.conf
sudo systemctl try-restart sshd

# Run the Cockpit web service with a privileged container (as root)
podman container runlabel --name cockpit-ws RUN quay.io/cockpit/ws

# Make Cockpit start at boot
podman container runlabel INSTALL quay.io/cockpit/ws
systemctl enable cockpit.service



I'm happy with it compared to Proxmox and the Proxmox forum moderators are probably also happy that I'm happy using something else because that means that they don't have questions from me that they obviously don't have the technical ability to solve. ;)

Best of luck and happy computing! :)
 
  • Like
Reactions: BeyondEvil
No. I was forced to run Proxmox with unencrypted drives. That seems to be implied by the moderators of this forum to be a more secure configuration than that having the drives be automatically unlocked with the TPM because the TPM might have some vulnerabilities that are unlikely to be exploited in my use case anyways. Yeah, wrap your head around them thinking that because the TPM might have a theoretical exploit that my better option would be to leave it in a configuration that would be the same result as if it were already exploited. Really makes you question what they're even thinking.

Best of luck and happy computing! :)

I was actually able to solve it using TPM. But then I wanted to extend it to the other storage I had, which I wasn't able to solve without having to input the passphrase on every boot. Kept going in circles. So I too abandoned it, not worth it for my homelab.

Thank you for the tip! Never heard about Cockpit, will definitely check it out.
 
Well I'm sorry to be that guy but this is something of a chicken/egg problem: You need to pass the key/passphrase to unlock the encrypted device but you don't want to have it available for an attacker. If you don't want to enter it after every reboot you would still need to save it somerwhere in clear text. I don't think that this can be solved
 
Nope, that's where the TPM comes in. It solves that bit. Like I said, I had it working for the boot disk.
 
Nope, that's where the TPM comes in. It solves that bit. Like I said, I had it working for the boot disk.
Assuming you have auto-unlock enabled for your system, because that was the use case you described:
What would prevent an attacker for just overriding the boot argument with e.g. init=/bin/bash and booting right in your decrypted OS or just doing what your current initrd is doing and injecting what he wants? That is one of the known attack vectors in a physical access scenario. What about DMA-based attacks? Also very easy doable in the scenario with physical access. What about a cold-boot attack?

TPM should be used with additional authentication in order to mitigate those issues or you should offload the encrypted disk description to another machine so that an attacker with physical access will not be able to encrypt it.
 
  • Like
Reactions: Johannes S

About

The Proxmox community has been around for many years and offers help and support for Proxmox VE, Proxmox Backup Server, and Proxmox Mail Gateway.
We think our community is one of the best thanks to people like you!

Get your subscription!

The Proxmox team works very hard to make sure you are running the best software and getting stable updates and security enhancements, as well as quick enterprise support. Tens of thousands of happy customers have a Proxmox subscription. Get yours easily in our online shop.

Buy now!