Ubuntu ZFS 加密 Home 目录

Ubuntu 20.04 的安装镜像支持 ZFS 文件系统:

/assets/images/posts/2020/09/install.png

本文是 安装后 加密 ZFS Home 目录的备忘教程。
另外有 安装前 加密 ZFS Root 文件系统的备忘教程。链接:《Ubuntu ZFS 原生全盘加密》

1、安装时创建一个随意的临时账号,或者安装完成后,新建一个临时管理员用户,暂且把这个账号叫做:tempuser,并把它设置为自动登录,此账号必须为管理员账号。
后面的步骤均在此临时账号下进行。

2、注销或重启后,登录 tempuser 账号,重新创建一个长期使用的用户,比如我的账号叫:eallion

3、查看 ZFS 数据集

1
sudo zfs list -r rpool

记录下你要用到的用户名的数据集名称,每个人的快照名字都不一样。
比如我的:eallion_c1doe6
返回值如图所示:

/assets/images/posts/2020/09/rpoollist.png

4、取消挂载新用户 eallion 的数据集

1
sudo zfs set mountpoint=none rpool/USERDATA/<yourdatasetname>

例如:

1
sudo zfs set mountpoint=none rpool/USERDATA/eallion_c1doe6

如果这一步遇到错误,如:target is busy,需要自行排错。比如我遇到的就是挂载了其他硬盘,导致不能取消数据集的挂载。

5、给新用户 eallion 创建一个新的加密数据集

1
sudo zfs create -o encryption=on -o keyformat=passphrase rpool/USERDATA/<yourusername>_encrypt

例如:

1
sudo zfs create -o encryption=on -o keyformat=passphrase rpool/USERDATA/eallion_encrypt

输入密码短语,回车。(一定要记住此密码。)

6、挂载这个加密数据集到新用户目录

1
sudo zfs set mountpoint=/home/<yourusername>  rpool/USERDATA/<yourusername>_encrypt

例如:

1
sudo zfs set mountpoint=/home/eallion  rpool/USERDATA/eallion_encrypt

7、检测一下是否配置正确(如果没有返回什么,就代表配置成功了)

1
sudo mount -a

8、检查一下加密是否成功(加密数据卷应该会有密码方式,如:aes-256-gcm

1
sudo zfs list -r rpool -o name,encryption

如图:
我用的是全盘加密,所以全部返回 aes-256-gcm
如果只加密了 Home 目录,则其他目录返回的是 None

/assets/images/posts/2020/09/encryption.png

9、让加密目录用上 ZFS 的自动快照功能,Grub 引导项中也能选择快照历史恢复系统。

1
sudo zfs set com.ubuntu.zsys:bootfs-datasets=rpool/ROOT/<nameofdataset> rpool/USERDATA/<yourusername>_encrypt

例如:(注意:你的数据集不一定叫 ubuntu_rroyp0,通过第 3 步可以查看。)

1
sudo zfs set com.ubuntu.zsys:bootfs-datasets=rpool/ROOT/ubuntu_rroyp0 rpool/USERDATA/eallion_encrypt

10、请确保 Home 目录的权限

1
sudo chown <yourusername>:<yourusername> /home/<yourusername>

例如:

1
sudo chown -R eallion:eallion /home/eallion

11、安装 ecryptfs-utils 加密交换空间 Swap

1
2
sudo apt install ecryptfs-utils
sudo ecryptfs-setup-swap

此时出现的一些错误提示例如 swapon: cannot open /dev/mapper/cryptswap1: No such file or device 可忽略。

12、查看一下是否成功

1
2
cat /etc/fstab
cat /etc/crypttab

PS、如果有多余的用户目录数据集占用空间,比如使用一段时间后才想起来想加密 Home 目录,老的数据集可以通过命令销毁,不过一定要记得备份重要数据。

1
sudo zfs destroy eallion1_123abc

Reference:
https://medium.com/@steinarlbergmyrvang/ubuntu-20-04-with-encrypted-home-f5ce490333cc

Pre-generated by ChatGPT 3.5
这篇文章介绍了如何在Ubuntu操作系统中使用ZFS文件系统加密Home目录。作者提供了详细的步骤指南,包括创建临时账号、查看ZFS数据集、取消挂载和创建加密数据集等。文章还介绍了如何检测和检查加密是否成功,以及如何使用ZFS的自动快照功能和Grub引导项。最后还提到了安装加密交换空间Swap的步骤和销毁旧的数据集的方法。