Arch Linux is known for its high level of customization, and configuring LUKS2 and LVM is a straightforward process. This guide provides a set of instructions for setting up an Arch Linux system with the following features:
- Root file system encryption using LUKS2.
- Logical Volume Management (LVM) for flexible storage management.
- Unified Kernel Image (UKI) bootable via UEFI.
- Optional: Detached LUKS header on external media for enhanced security.
Prerequisites
- A bootable Arch Linux ISO.
- An NVMe drive (e.g., /dev/nvme0n1).
- (Optional) A microSD card or other external medium for the detached LUKS header.
Important Considerations
- Data Loss: The following procedure will erase all data on the target drive. Back up any important data before proceeding.
- Secure Boot: This guide assumes you may want to use hardware secure boot.
- Detached LUKS Header: Using a detached LUKS header on external media adds a significant layer of security. If you lose the external media, you will lose access to your encrypted data.
- Swap: This guide uses a swap file. You may also use a swap partition if desired.
Step-by-Step Instructions
- 
                Boot into the Arch Linux ISO:Boot your system from the Arch Linux installation media. 
- 
                Set the System Clock:# timedatectl set-ntp true
- 
                Prepare the Disk:- Identify your NVMe drive (e.g., /dev/nvme0n1). Uselsblkto confirm.
- Wipe the drive:
 # wipefs --all /dev/nvme0n1
- Identify your NVMe drive (e.g., 
- Create an EFI System Partition (ESP):
- Create a partition for the encrypted volume:
- 
                Set up LUKS2 Encryption:Encrypt the second partition using LUKS2. This example uses aes-xts-plain64andserpent-xts-plainciphers, and SHA512 for the hash. Adjust as needed.# cryptsetup luksFormat --cipher aes-xts-plain64 --keyslot-cipher serpent-xts-plain --keyslot-key-size 512 --use-random -S 0 -h sha512 -i 4000 /dev/nvme0n1p2- --cipher: Specifies the cipher for data encryption.
- --keyslot-cipher: Specifies the cipher used to encrypt the key.
- --keyslot-key-size: Specifies the size of the key slot
- -S 0: Disables sparse headers.
- -h: Specifies the hash function.
- -i: Specifies the number of iterations.
 Open the encrypted partition: # cryptsetup open /dev/nvme0n1p2 root
- 
                Create the File Systems and Mount:Create an ext4 file system on the decrypted volume: # mkfs.ext4 /dev/mapper/rootMount the root file system: # mount /dev/mapper/root /mntCreate and mount the EFI System Partition: # mkfs.fat -F32 /dev/nvme0n1p1 # mount --mkdir /dev/nvme0n1p1 /mnt/efiCreate and enable a swap file: # dd if=/dev/zero of=/mnt/swapfile bs=1M count=8000 status=progress # chmod 600 /mnt/swapfile # mkswap /mnt/swapfile # swapon /mnt/swapfile
- 
                Install the Base System:Use pacstrapto install the necessary packages:# pacstrap -K /mnt base base-devel linux linux-hardened linux-hardened-headers linux-firmware apparmor mesa xf86-video-intel vulkan-intel git vi vim ukify
- 
                Generate the fstab File:# genfstab -U /mnt >> /mnt/etc/fstab
- 
                Chroot into the New System:# arch-chroot /mnt
- 
                Configure the System:Set the timezone: # ln -sf /usr/share/zoneinfo/UTC /etc/localtime # hwclock --systohcUncomment en_US.UTF-8 UTF-8in/etc/locale.genand generate the locale:# sed -i 's/#'"en_US.UTF-8"' UTF-8/'"en_US.UTF-8"' UTF-8/g' /etc/locale.gen # locale-gen # echo 'LANG=en_US.UTF-8' > /etc/locale.conf # echo "KEYMAP=us" > /etc/vconsole.confSet the hostname: # echo myhostname > /etc/hostname # cat <> /etc/hosts 127.0.0.1 myhostname ::1 localhost 127.0.1.1 myhostname.localdomain myhostname EOTConfigure mkinitcpio.confto include theencrypthook:# sed -i 's/HOOKS.*/HOOKS=(base udev autodetect modconf kms keyboard keymap consolefont block encrypt filesystems resume fsck)/' /etc/mkinitcpio.confCreate the initial ramdisk: # mkinitcpio -PInstall the bootloader: # bootctl installSet the root password: # passwdInstall microcode and efibootmgr: # pacman -S intel-ucode efibootmgrGet the swap offset: # swapoffset=`filefrag -v /swapfile | awk '/\s+0:/ {print $4}' | sed -e 's/\.\.$//'`Get the UUID of the encrypted partition: # blkid -s UUID -o value /dev/nvme0n1p2Create the EFI boot entry. Replace <UUID OF CRYPTDEVICE>with the actual UUID from the previous step.# efibootmgr --disk /dev/nvme0n1p1 --part 1 --create --label "Linux" --loader /vmlinuz-linux --unicode "cryptdevice=UUID=<UUID OF CRYPTDEVICE>:root root=/dev/mapper/root resume=/dev/mapper/root resume_offset=$swapoffset rw initrd=\intel-ucode.img initrd=\initramfs-linux.img" --verboseConfigure the UKI presets: # cat <> /etc/mkinitcpio.d/linux.preset ALL_kver="/boot/vmlinuz-linux" ALL_microcode=(/boot/*-ucode.img) PRESETS=('default' 'fallback') default_uki="/efi/EFI/Linux/arch-linux.efi" default_options="--splash /usr/share/systemd/bootctl/splash-arch.bmp" fallback_uki="/efi/EFI/Linux/arch-linux-fallback.efi" fallback_options="-S autodetect" EOTCreate the UKI directory: # mkdir -p /efi/EFI/LinuxConfigure the kernel command line: # cat <> /etc/kernel/cmdline cryptdevice=UUID=<UUID OF CRYPTDEVICE>:root root=/dev/mapper/root resume=/dev/mapper/root resume_offset=51347456 rw EOTBuild the UKIs: # mkinitcpio -p linuxConfigure the kernel install layout: # echo "layout=uki" >> /etc/kernel/install.conf
- 
                Configure Networking (Optional):Create a systemd-networkd network configuration file: # cat <> /etc/systemd/network/nic0.network [Match] Name=nic0 [Network] DHCP=yes EOT
- 
                Install a Desktop Environment (Optional):Install Xorg, Xfce, LightDM, and related packages: # pacman -Syu # pacman -S xorg xfce4 xfce4-goodies lightdm lightdm-gtk-greeter libva-intel-driver mesa xorg-server xorg-xinit sudo # systemctl enable lightdm # systemctl start lightdm
- 
                Enable Network Services (Optional):# systemctl enable systemd-resolved.service # systemctl enable systemd-networkd.service # systemctl start systemd-resolved.service # systemctl start systemd-networkd.service
- 
                Create a User Account:Create a user account and add it to the wheelgroup:# useradd -m -g wheel -s /bin/bash myusername
- 
                Reboot:Exit the chroot environment and reboot your system: # exit # umount -R /mnt # reboot
# sgdisk /dev/nvme0n1 -n 1::+512MiB -t 1:EF00# sgdisk /dev/nvme0n1 -n 2 -t 2:8300
