- Introduction
- Preliminary Steps
- Main installation
- Disk partitioning
- Disk formatting
- Packages installation
- Fstab
- Context switch to our new system
- Set up the time zone
- Set up the language and tty keyboard map
- Hostname and Host configuration
- Root and users
- Grub configuration
- Unmount everything and reboot
- Automatic snapshot boot entries update
- Virtual machine [Optional]
- Aur helper and additional packages installation [Optional]
- Finalization
 
- Video drivers
- Setting up a graphical environment
- Adding a display manager
- Gaming
- Things to add [WIP]
In this guide I'll show how to install Arch Linux with BTRFS on an UEFI system. I'll comment each step to make it understandable. Apart from the basic terminal installation I'll add steps to install video drivers, a desktop environment and to configure arch for gaming. All of this done in an elegant and minimalistic approach which I like to consider modern.
During the process you will find out that certain choices are completely personal like: disk partitioning, BTRFS subvolume creation, pacstrap package choices etc.. As such I will alert you with tags in square brackets like: [Optional:] and provide external references to learn how to adjust things to your needs.
I won't prepare the system for secure boot because the procedure of custom key enrollment in the BIOS is dangerous and can lead to a bricked system, read the warnings here. If you are wondering why not using the default OEM keys in the BIOS, it's because they will make secure boot useless by being most likely not enough secure, as the arch wiki states.
I won't encrypt the system because I don't need it and has few uses cases in which is actually needed ( you can always encrypt sensible information with gpg ). Also the boot would become inevitably slower.
I'll skip the Arch ISO download, gpg signature check and installation media preparation.
I'll use a wired connection, so no wireless configuration steps will be shown. If you want to connect to wifi, you can either launch wifi-menu from the terminal which is a TGUI or use iwctl.
First set up your keyboard layout
# List all the available keyboard maps and filter them through grep, in this case i am looking for an italian keyboard, which usually starts with "it", for english filter with "en"
ls /usr/share/kbd/keymaps/**/*.map.gz | grep it
# If you prefer you can scroll the whole list like this
ls /usr/share/kbd/keymaps/**/*.map.gz | less
# Or like this
localectl list-keymaps
# Now get the name without the path and the extension ( localectl returns just the name ) and load the layout. In my case it is simply "it"
loadkeys itCheck that we are in UEFI mode
# If this command prints 64 or 32 then you are in UEFI
cat /sys/firmware/efi/fw_platform_sizeCheck the internet connection
ping -c 5 archlinux.org Check the system clock just in case
# Check if ntp is active and if the time is right
timedatectlI will make 2 partitions:
| Number | Type | Size | 
|---|---|---|
| 1 | EFI | 512 Mb | 
| 2 | Linux Filesystem | 99.5Gb (all of the remaining space ) | 
# Check the drive name. Mine is /dev/nvme0n1
# If you have an hdd is something like sdax
fdisk -l
# Invoke fdisk to partition
fdisk /dev/nvme0n1
# Now press the following commands, when i write ENTER press enter
g
ENTER
n
ENTER
ENTER
ENTER
+512M
ENTER
t
ENTER
ENTER
1
ENTER
n
ENTER
ENTER
ENTER # If you don't want to use all the space then select the size by writing +XG ( eg: to make a 10GB partition +10G )
p
ENTER # Now check if you got the partitions right
# If so write the changes
w
ENTER
# If not you can quit without saving and redo from the beginning
q
ENTER# Find the efi partition with fdisk -l or lsblk. For me it's /dev/nvme0n1p1 and format it.
mkfs.fat -F 32 /dev/nvme0n1p1
# Find the root partition. For me it's /dev/nvme0n1p2 and format it. I will use BTRFS.
mkfs.btrfs /dev/nvme0n1p2
# Mount the root fs to make it accessible
mount /dev/nvme0n1p2 /mntNote: if you don't want BTRFS, you can go with the standard
ext4format, but in that case you should skip all of the btrfs steps in this guide
# Create the subvolumes, in my case I choose to make a subvolume for / and one for /home. Subvolumes are identified by prepending @
btrfs subvolume create /mnt/@
btrfs subvolume create /mnt/@home
# Unmount the root fs
umount /mntFor this guide I'll compress the root partition thanks to BTRF capabilities with Zstd, which is the fastest compression algorithm available
# Mount the root and home subvolume. If you don't want compression just remove the compress option.
mount -o compress=zstd,subvol=@ /dev/nvme0n1p2 /mnt
mkdir -p /mnt/home
mount -o compress=zstd,subvol=@home /dev/nvme0n1p2 /mnt/homeNow we have to mount the efi partition. There are 2 main mountpoints to use: /efi or /boot. I'll choose /efi because it grants separation of concerns and also is a good choice if one wants to encrypt /boot, since you can't encrypt efi files. Learn more here
mkdir -p /mnt/efi
mount /dev/nvme0n1p1 /mnt/efi# This will install some packages to "bootstrap" methaphorically our system. Feel free to add the ones you want
# "base, linux, linux-firmware" are needed
# "base-devel" base development packages
# "git" to install the git vcs
# "btrfs-progs" are user-space utilities for file system management ( needed to harness the potential of btrfs )
# "grub" the bootloader
# "efibootmgr" needed to install grub
# "grub-btrfs" adds btrfs support for the grub bootloader and enables the user to directly boot from snapshots
# "inotify-tools" used by grub btrfsd deamon to automatically spot new snapshots and update grub entries
# "timeshift" a GUI app to easily create,plan and restore snapshots using BTRFS capabilities
# "amd-ucode" microcode updates for the cpu. If you have an intel one use "intel-ucode"
# "vim" my goto editor, if unfamiliar use nano
# "networkmanager" to manage Internet connections both wired and wireless ( it also has an applet package network-manager-applet )
# "pipewire pipewire-alsa pipewire-pulse pipewire-jack" for the new audio framework replacing pulse and jack. You should be prompted to choose a session manager, I'll choose Wireplumber.
# "reflector" to manage mirrors for pacman
# "zsh" my favourite shell
# "zsh-completions" for zsh additional completions
# "zsh-autosuggestions" very useful, it helps writing commands [ Needs configuration in .zshrc ]
# "openssh" to use ssh and manage keys
# "man" for manual pages
# "sudo" to run commands as other users
pacstrap /mnt base base-devel linux linux-firmware git btrfs-progs grub efibootmgr grub-btrfs inotify-tools timeshift vim networkmanager pipewire pipewire-alsa pipewire-pulse pipewire-jack reflector zsh zsh-completions zsh-autosuggestions openssh man sudo# Fetch the disk mounting points as they are now ( we mounted everything before ) and generate instructions to let the system know how to mount the various disks automatically
genfstab -U /mnt >> /mnt/etc/fstab
# Check if fstab is fine
cat /mnt/etc/fstab# To access our new system we chroot into it
arch-chroot /mnt# In our new system we have to set up the local time zone, find your one in /usr/share/zoneinfo mine is /usr/share/zoneinfo/Europe/Rome and create a symbolic link to /etc/localtime
ln -sf /usr/share/zoneinfo/Europe/Rome /etc/localtime
# Now sync the time to the hardware clock
hwclock --systohcEdit /etc/locale.gen and uncomment the entries for your locales, this will "enable" ( NOT ACTIVATE ) the language but also formats for time, date, currency and other country related settings. In my case I will uncomment ( ie: remove the # ) en_US.UTF-8 UTF-8 and it_IT.UTF-8 UTF-8 because I use English as a "display" language and Italian for date, time and other formats.
# To edit I will use vim, feel free to use nano instead.
vim /etc/locale.gen
# Now generate the locales
locale-genCreate the configuration file /etc/locale.conf and set the locale to the desired one, by setting the LANG variable accordingly. In my case I'll write LANG=it_IT.UTF-8 to apply Italian settings to everything and then override only the display language to English by setting LC_MESSAGES=en_US.UTF-8. ( if you want formats and language to stay the same DON'T set LC_MESSAGES  ). More on this here
touch /etc/locale.conf
vim /etc/locale.confNow to make the current keyboard layout permanent for tty sessions , create /etc/vconsole.conf and write KEYMAP=your_key_map substituting the keymap with the one previously set here. In my case KEYMAP=it
vim /etc/vconsole.conf# Create /etc/hostname then choose and write the name of your pc in the first line. In my case I'll use Arch
touch /etc/hostname
vim /etc/hostname
# Create the /etc/hosts file. This is very important because it will resolve the listed hostnames locally and not over the Internet.
touch /etc/hostsWrite the following ip, hostname pairs inside /etc/hosts, replacing Arch with YOUR hostname:
127.0.0.1 localhost
::1 localhost
127.0.1.1 Arch
# Edit the file with the information above
vim /etc/hosts# Set up the root password
passwd
# Add a new user, in my case mjkstra.
# -m creates the home dir automatically
# -G adds the user to an initial group, in this case is wheel, the administration group. 
useradd -mG wheel mjkstra
passwd mjkstra
# Uncomment the wheel group to allow execution of any command( ie: remove the # from the wheel line ). if you want to use nano then write EDITOR=nano instead.
EDITOR=vim visudoNow I'll deploy grub
grub-install --target=x86_64-efi --efi-directory=/efi --bootloader-id=GRUB  Generate the grub configuration ( it will include the microcode installed with pacstrap earlier )
grub-mkconfig -o /boot/grub/grub.cfg# Enable newtork manager before rebooting otherwise, you won't be able to connect
systemctl enable NetworkManager
# Enable the network time synchronization
timedatectl set-ntp true
# Exit from chroot
exit
# Unmount everything to check if the drive is busy
umount -R /mnt
# Reboot the system and unplug the installation media
rebootEdit grub-btrfsd service to enable automatic grub entries update each time a snapshot is created. Because I will use timeshift i am going to replace ExecStart=... with ExecStart=/usr/bin/grub-btrfsd --syslog --timeshift-auto. If you don't use timeshift or prefer to manually update the entries then lookup here
sudo systemctl edit --full grub-btrfsd
# Enable grub-btrfsd service to run on boot
sudo systemctl enable grub-btrfsdFollow these steps if you are running Arch on a Virtualbox VM.
# Install the guest utils
pacman -S virtualbox-guest-utils
# Enable this service to automatically load the kernel modules
systemctl enable vboxservice.serviceNote: the utils will only work after a reboot is performed.
Warning: the utils seems to only work in a graphical environment.
To gain access to the arch user repository we need an aur helper, I will choose yay which also works as a pacman wrapper ( which means you can use yay instead of pacman. Cool, right ? ). Yay has a CLI, but if you later want to have an aur helper with a GUI, I advise installing pamac, which is the default on Manjaro.
To learn more about yay read here
Note: you can't execute makepkg as root, so you need to log in your main account. For me it's mjkstra
# Install yay
pacman -S --needed git base-devel && git clone https://aur.archlinux.org/yay.git && cd yay && makepkg -si
# Install "timeshift-autosnap", a configurable pacman hook which automatically makes snapshots before pacman upgrades.
yay -S timeshift-autosnapLearn more about timeshift autosnap here
# To complete the main/basic installation reboot the system
rebootAfter these steps you should be able to boot on your newly installed Arch Linux, if so congrats !
The basic installation is complete and you could stop here, but if you want to to have a graphical session, you can continue reading the guide.
In order to have the smoothest experience on a graphical environment, Gaming included, we first need to install video drivers. To help you choose which one you want or need, read this section of the arch wiki.
Note: skip this section if you are on a Virtual Machine
For this guide I'll install the AMDGPU driver which is the open source one and the recommended, but be aware that this works starting from the GCN 3 architecture, which means that cards before RX 400 series are not supported. ( FYI I have an RX 5700 XT )
# What are we installing ?
# mesa: DRI driver for 3D acceleration
# xf86-video-amdgpu: DDX driver for 2D acceleration in Xorg
# vulkan-radeon: vulkan support
# libva-mesa-driver: VA-API h/w video decoding support
# mesa-vdpau: VDPAU h/w accelerated video decoding support
sudo pacman -S mesa xf86-video-amdgpu vulkan-radeon libva-mesa-driver mesa-vdpauIF you want add 32-bit support, we need to enable the multilib repository on pacman: edit /etc/pacman.conf and uncomment the [multilib] section ( ie: remove the hashtag from each line of the section. Should be 2 lines ). Now we can install the additional packages.
# Refresh and upgrade the system
yay
# Install 32bit support for mesa, vulkan, VA-API and VDPAU
pacman -S lib32-mesa lib32-vulkan-radeon lib32-libva-mesa-driver lib32-mesa-vdpauIn summary if you have an Nvidia card you have 2 options:
I won't explain further because I don't have an Nvidia card and the process for such cards is tricky unlike for AMD or Intel cards. Moreover for reason said before, I can't even test it.
Installation looks almost identical to the AMD one, but every time a package contains the radeon word substitute it with intel. However this does not stand for h/w accelerated decoding, and to be fair I would recommend reading the wiki before doing anything.
I'll provide 2 options:
- KDE-plasma
- Hyprland
On top of that I'll add a display manager, which you can omit if you don't like ( if so, you have additional configuration steps to perform ).
KDE Plasma is a very popular DE which comes bundled in many distributions. It supports both the older more stable Xorg and the newer Wayland protocols. It's user friendly and also it's used on the Steam Deck, which makes it great for gaming. I'll provide the steps for a minimal installation and add some basic packages.
# Install the plasma desktop environment, the audio and network applets, task manager, screen configurator, global shortcuts, power manager, some useful basic addons, configuration for GTK application theming and other package of personal interest
pacman -S plasma-desktop plasma-pa plasma-nm plasma-systemmonitor kscreen khotkeys powerdevil kdeplasma-addons kde-gtk-config breeze-gtk alacritty dolphin firefox kate okular mpv gimpNow don't reboot your system yet. If you want a display manager, which is generally recommended, head to the related section in this guide and proceed from there otherwise you'll have to manually configure and launch the graphical environment each time (which I would advise to avoid).
Hyprland is a tiling WM that sticks to the wayland protocol. It looks incredible and it's one of the best Wayland WMs right now. It's based on wlroots the famous library used by Sway, the most compatible/working Wayland WM there is. I don't know if I would recommend this to beginners because it's a different experience from Windows/Ubuntu/PopOs and distros like that, moreover it requires you to read the guide for configuration. The good part is that even if it seems discouraging, it's actually an easy read because it is written beautifully even better than the Arch wiki !
# Install hyprland from tagged releases and other utils
pacman -S --needed hyprland swaylock wofi waybar dolphin alacritty
yay -S wlogoutNote: this section needs configuration and misses a lot of stuff, I don't know when and if I will expand it but at least you have a starting point, which is the wiki and the master tutorial
Display managers are useful when you have multiple DE or WMs and want to choose where to boot from in a GUI fashion, also they take care of the launch process. I'll show the installation process of SDDM, which is highly customizable and compatible.
Note: hyprland does not support any display manager, however SDDM is reported to work flawlessly from the wiki
# Install SDDM
sudo pacman -S sddm
# Enable SDDM service to make it start on boot
sudo systemctl enable sddm
# If using KDE I suggest installing this to control the SDDM configuration from the KDE settings App
pacman -S --needed sddm-kcm
# Now it's time to reboot the system
rebootGaming on linux has become a very fluid experience, so I'll give some tips on how to setup your arch distro for gaming.
Let's break down what is needed to game:
- Gaming client ( eg: Steam, Lutris, Bottles, etc..)
- Windows compatibility layers ( eg: Proton, Wine, DXVK, VKD3D )
Optionally we can have:
- Generic optimization ( eg: gamemode )
- Overclocking and monitoring software ( eg: CoreCtrl, Mangohud )
- Custom kernels
I'll install Steam and to access games from other launchers I'll use Bottles, which should be installed through flatpak.
# Install steam and flatpak
pacman -S steam flatpak
# Install bottles through flatpak
flatpak install flathub com.usebottles.bottlesProton is the compatibility layer developed by Valve, which includes DXVK( DirectX 9-10-11 to Vulkan), VKD3D ( DirectX 12 to Vulkan ) and a custom version of Wine. It is embedded in Steam and can be enabled directly in Steam settings. A custom version of proton, Proton GE exists and can be used as an alternative if something is broken or doesn't perform as expected. Can be either downloaded manually, like explained here or through yay as below.
# Installation through yay
yay -S proton-ge-custom-binTips: To have a more fluid shader compilation when using steam, enable from its settings shader precaching and background processing of vulkan shaders
We can use gamemode to gain extra performance. To enable it read here
# Install gamemode
pacman -S gamemodeTo live monitor your in-game performance, you can use mangohud. To enable it read here
# Install mangohud
pacman -S mangohudTo overclock your system, i suggest installing corectrl if you have an AMD Gpu or TuxClocker for NVIDIA.
Tip: On KDE disabling mouse acceleration is simple, just go to the settings via the GUI and on the mouse section enable the flat acceleration profile. If not using KDE then read here
Tip: To enable freesync or Gsync you can read here, depending on your session ( Wayland or Xorg ) and your gfx provider ( Nvidia, AMD, Intel ) the steps may differ.
About custom kernels: To be fair I don't recommend changing the kernel to a custom one, for many reasons:
- You have to manually update it and recompile it each time unless you use a precompiled kernel from pacman or aur such as
linux-zen- Performance gain is little to none and sometimes it may results in losses with other scenarios
- In my opinion changing to a custom kernel should be considered only if you experience problems or for the sake of science
- Additional pacman configuration ( paccache, colors, download packages simultaneously )
- Reflector configuration