Installation guide - ArchWiki
Packages
Forums
Wiki
GitLab
Security
AUR
Jump to content
This page is protected so that only users with the "sysop" permission can edit it.
From ArchWiki
This document is a guide for installing
Arch Linux
using the live system booted from an installation medium made from an official installation image. The installation medium provides accessibility features which are described on the page
Install Arch Linux with accessibility options
. For alternative means of installation, see
Category:Installation process
Before installing, it would be advised to view the
FAQ
. For conventions used in this document, see
Help:Reading
. In particular, code examples may contain placeholders (formatted in
italics
) that must be replaced manually.
This guide is kept concise and you are advised to follow the instructions in the presented order per section. For more detailed instructions, see the respective
ArchWiki
articles or the various programs'
man pages
, both linked from this guide. For interactive help, the
IRC channel
and the
forums
are also available.
Arch Linux should run on any
x86_64
-compatible machine with a minimum of 512 MiB RAM, though more memory is needed to boot the live system for installation.
[1]
A basic installation should take less than 2 GiB of disk space. As the installation process needs to retrieve packages from a remote repository, this guide assumes a working internet connection is available.
Pre-installation
Acquire an installation image
Visit the
page and, depending on how you want to boot, acquire the ISO file or a netboot image, and the respective PGP signature.
Verify signature
It is recommended to verify the image signature before use, especially when downloading from an
HTTP mirror
, where downloads are generally prone to be intercepted to
serve malicious images
Download the
ISO PGP signature
from
to the ISO directory and follow the instructions there to verify it.
Alternatively, from an existing Arch Linux installation run:
$ pacman-key -v archlinux-
version
-x86_64.iso.sig
Note
The signature itself could be manipulated if it is downloaded from a mirror site, instead of from
archlinux.org
. In this case, ensure that the public key, which is used to decode the signature, is signed by another, trustworthy key. The
gpg
command will output the fingerprint of the public key.
Another method to verify the authenticity of the signature is to ensure that the public key's fingerprint is identical to the key fingerprint of the
Arch Linux developer
who signed the ISO-file. See
Wikipedia:Public-key cryptography
for more information on the public-key process to authenticate keys.
Prepare an installation medium
The ISO can be supplied to the target machine via a
USB flash drive
, an
optical disc
or a network with
PXE
: follow the appropriate article to prepare yourself an installation medium from the ISO file.
For the netboot image, follow
Netboot#Boot from a USB flash drive
to prepare a USB flash drive for UEFI booting.
Boot the live environment
Note
Arch Linux installation images do not support Secure Boot. You will need to
disable Secure Boot
to boot the installation medium. If desired,
Secure Boot
can be set up after completing the installation.
Point the current boot device to the one which has the Arch Linux installation medium. Typically it is achieved by pressing a key during the
POST
phase, as indicated on the splash screen. Refer to your motherboard's manual for details.
When the installation medium's boot loader menu appears,
if you used the ISO, select
Arch Linux install medium
and press
Enter
to enter the installation environment.
if you used the Netboot image, choose a geographically close mirror from
Mirror
menu, then select
Boot Arch Linux
and press
Enter
Tip
The ISO uses
systemd-boot
for UEFI and
syslinux
for BIOS booting. Use respectively
or
Tab
to enter the
boot parameters
. The Netboot image uses iPXE and the boot parameters can be specified in the
Boot options
menu. See
/usr/share/doc/mkinitcpio-archiso/README.bootparams
for a list.
A common example of manually defined boot parameter would be the font size. For better readability on HiDPI screens—when they are not already recognized as such—using
fbcon=font:TER16x32
can help. See
HiDPI#Linux console (tty)
for a detailed explanation.
You will be logged in on the first
virtual console
as the root user, and presented with a
Zsh
shell prompt.
To switch to a different console—for example, to view this guide with
Lynx
alongside the installation—use the
Alt+
arrow
keyboard shortcut
. To
edit
configuration files,
mcedit(1)
nano
and
vim
are available. See
pkglist.x86_64.txt
for a list of the packages included in the installation medium.
Set the console keyboard layout and font
The default
console keymap
is
US
. Available layouts can be listed with:
# localectl list-keymaps
To set the keyboard layout, pass its name to
loadkeys(1)
. For example, to set a
German
keyboard layout:
# loadkeys de-latin1
Console fonts
are located in
/usr/share/kbd/consolefonts/
and can likewise be set with
setfont(8)
omitting the path and file extension. For example, to use one of the largest fonts suitable for
HiDPI screens
, run:
# setfont ter-132b
Verify the boot mode
To verify the boot mode, check the
UEFI bitness
# cat /sys/firmware/efi/fw_platform_size
If the command returns
64
, the system is booted in UEFI mode and has a 64-bit x64 UEFI.
If the command returns
32
, the system is booted in UEFI mode and has a 32-bit IA32 UEFI. While this is supported, it will limit the boot loader choice to those that support mixed mode booting.
If it returns
No such file or directory
, the system may be booted in
BIOS
(or
CSM
) mode.
If the system did not boot in the mode you desired (UEFI vs BIOS), refer to your motherboard's manual.
Connect to the internet
To set up a network connection in the live environment, go through the following steps:
Ensure your
network interface
is listed and enabled, for example with
ip-link(8)
# ip link
For wireless and WWAN, make sure the card is not blocked with
rfkill
Connect to the network:
Ethernet—plug in the cable.
Wi-Fi—authenticate to the wireless network using
iwctl
Mobile broadband modem—connect to the mobile network with the
mmcli
utility.
Configure your network connection:
DHCP
: dynamic IP address and DNS server assignment (provided by
systemd-networkd
and
systemd-resolved
) should work out of the box for Ethernet, WLAN, and WWAN network interfaces.
Static IP address: follow
Network configuration#Static IP address
The connection may be verified with
ping
# ping ping.archlinux.org
Note
In the installation image,
systemd-networkd
systemd-resolved
iwd
and
ModemManager
are preconfigured and enabled by default. That will not be the case for the installed system.
Update the system clock
The live system needs accurate time to prevent package signature verification failures and TLS certificate errors. The
systemd-timesyncd
service is enabled by default in the live environment and time will be synchronized automatically once a connection to the internet is established.
Use
timedatectl(1)
to ensure the system clock is synchronized:
# timedatectl
Partition the disks
When recognized by the live system, disks are assigned to a
block device
such as
/dev/sda
/dev/nvme0n1
or
/dev/mmcblk0
. To identify these devices, use
lsblk
or
fdisk
# fdisk -l
Results ending in
rom
loop
or
airootfs
may be ignored.
mmcblk*
devices ending in
rpmb
boot0
and
boot1
can be ignored.
Note
If the disk does not show up,
make sure the disk controller is not in RAID mode
Tip
Check that your NVMe drives and Advanced Format hard disk drives are using the
optimal logical sector size
before partitioning.
The following
partitions
are
required
for a chosen device:
One partition for the
root directory
For booting in
UEFI
mode: an
EFI system partition
Use a
partitioning tool
like
fdisk
to modify partition tables. For example:
# fdisk
/dev/the_disk_to_be_partitioned
Note
Take time to plan a long-term partitioning scheme to avoid risky and complicated conversion or re-partitioning procedures in the future.
If you want to create any stacked block devices for
LVM
system encryption
or
RAID
, do it now.
If the disk from which you want to boot
already has an EFI system partition
, do not create another one, but use the existing partition instead.
Swap
space can be set on a
swap file
for file systems supporting it. Alternatively, disk based swap can be avoided entirely by setting up
swap on zram
after installing the system.
Example layouts
UEFI with
GPT
Mount point on the installed system
Partition
Partition type
Suggested size
/boot
/dev/
efi_system_partition
EFI system partition
1 GiB
[SWAP]
/dev/
swap_partition
Linux swap
At least 4 GiB
/dev/
root_partition
Linux x86-64 root (/)
Remainder of the device. At least 23–32 GiB.
Other mount points
, such as
/efi
, are possible, provided that the used boot loader is capable of loading the kernel and initramfs images from the root volume. See the warning in
Arch boot process#Boot loader
BIOS with
MBR
Mount point on the installed system
Partition
Partition type
Suggested size
[SWAP]
/dev/
swap_partition
Linux swap
At least 4 GiB
/dev/
root_partition
Linux
Remainder of the device. At least 23–32 GiB.
See also
Partitioning#Example layouts
Format the partitions
Once the partitions have been created, each newly created partition must be formatted with an appropriate
file system
. See
File systems#Create a file system
for details.
For example, to create an
Ext4
file system on
/dev/
root_partition
, run:
# mkfs.ext4 /dev/
root_partition
If you created a partition for
swap
, initialize it with
mkswap(8)
# mkswap /dev/
swap_partition
Note
For stacked block devices replace
/dev/
*_partition
with the appropriate block device path.
If you created an EFI system partition,
format it
to FAT32 using
mkfs.fat(8)
Warning
Only format the EFI system partition if you created it during the partitioning step. If there already was an EFI system partition on disk beforehand, reformatting it can destroy the boot loaders of other installed operating systems.
# mkfs.fat -F 32 /dev/
efi_system_partition
Mount the file systems
Mount
the root volume to
/mnt
. For example, if the root volume is
/dev/
root_partition
# mount /dev/
root_partition
/mnt
Create any remaining mount points under
/mnt
(such as
/mnt/boot
for
/boot
) and mount the volumes in their corresponding hierarchical order.
Tip
Run
mount(8)
with the
--mkdir
option to create the specified mount point. Alternatively, create it using
mkdir(1)
beforehand.
For UEFI systems, mount the EFI system partition. For example:
# mount --mkdir /dev/
efi_system_partition
/mnt/boot
If you created a
swap
volume, enable it with
swapon(8)
# swapon /dev/
swap_partition
genfstab(8)
will later detect mounted file systems and swap space.
Installation
Select the mirrors
Packages to be installed must be downloaded from
mirror servers
, which are defined in
/etc/pacman.d/mirrorlist
. The higher a mirror is placed in the list, the more priority it is given when downloading a package.
On the live system, all HTTPS mirrors are enabled (i.e. uncommented). The topmost worldwide mirror should be fast enough for most people, but you may still want to inspect the file to see if it is satisfactory. If it is not,
edit
the file accordingly, and move the geographically closest mirrors to the top of the list, although other criteria should be taken into account. Alternatively, you can use
reflector
to create a mirrorlist file based on various criteria.
This file will later be copied to the new system by
pacstrap
, so it is worth getting right.
Install essential packages
No configuration (except for
/etc/pacman.d/mirrorlist
) gets carried over from the live environment to the installed system. The only mandatory package to install is
base
, which
does not
include all tools from the live installation, so installing more packages is frequently necessary.
In particular, review the following software and install everything that you need:
CPU
microcode
updates—
amd-ucode
or
intel-ucode
—for hardware bug and security fixes,
userspace utilities for file systems
that will be used on the system—for the purposes of e.g. file system creation and
fsck
utilities for accessing and managing
RAID
or
LVM
if they will be used on the system,
specific
firmware
for other devices not included in
linux-firmware
(e.g.
sof-firmware
for
onboard audio
linux-firmware-marvell
for Marvell wireless and any of the multiple firmware packages for
Broadcom wireless
),
software necessary for
networking
(e.g.
a network manager or a standalone DHCP client
authentication software
for Wi-Fi,
ModemManager
for mobile broadband connections),
console text editor
(e.g
nano
) to allow editing configuration files from the console,
packages for accessing documentation in
man
and
info
pages:
man-db
man-pages
and
texinfo
For comparison, packages available in the live system can be found in
pkglist.x86_64.txt
To install more packages or package groups, append the names to the
pacstrap(8)
command below (space separated) or use
pacman
to
install
them while
chrooted into the new system
For example, a basic installation with the Linux
kernel
and firmware for common hardware:
# pacstrap -K /mnt base linux linux-firmware
Tip
You can substitute
linux
with a
kernel
package of your choice, or you could omit it entirely when installing in a
container
You could omit the installation of the firmware package when installing in a virtual machine or container.
This initial package selection in pacstrap only needs to include what is required for the system to boot; all other software can be installed or replaced post-installation.
Configure the system
Fstab
To get needed file systems (like the one used for the boot directory
/boot
) mounted on startup, generate an
fstab
file with
persistent block device naming
using
genfstab(8)
. For example, reference file systems by their
UUIDs
with
-U
# genfstab -U /mnt >> /mnt/etc/fstab
Check the resulting
/mnt/etc/fstab
file, and
edit
it in case of errors.
Chroot
To directly interact with the new system's environment, tools, and configurations for the next steps as if you were booted into it,
change root
into the new system:
# arch-chroot /mnt
Note
Some
systemd
tools such as
hostnamectl(1)
localectl(1)
and
timedatectl(1)
cannot be used inside a
chroot(1)
, as they require an active
dbus
connection.
[2]
Time
For human convenience (e.g. showing the correct local time or handling Daylight Saving Time), set the
time zone
# ln -sf /usr/share/zoneinfo/
Area
Location
/etc/localtime
Run
hwclock(8)
to generate
/etc/adjtime
# hwclock --systohc
This command assumes the hardware clock is set to
UTC
. See
System time#Time standard
for details.
To prevent clock drift and ensure accurate time, set up
time synchronization
using a
Network Time Protocol
(NTP) client such as
systemd-timesyncd
Localization
To use the correct region and language specific formatting (like dates, currency, decimal separators),
edit
/etc/locale.gen
and uncomment the UTF-8
locales
you will be using. Generate the locales by running:
# locale-gen
Create
the
locale.conf(5)
file, and
set the LANG variable
accordingly:
/etc/locale.conf
LANG=
en_US.UTF-8
If you
set the console keyboard layout
, make the changes persistent in
vconsole.conf(5)
/etc/vconsole.conf
KEYMAP=
de-latin1
Network configuration
To assign a consistent, identifiable name to your system (particularly useful in a networked environment),
create
the
hostname
file:
/etc/hostname
yourhostname
Tip
For advice on choosing a hostname, see
RFC 1178
. As explained in
hostname(7)
, it must contain from 1 to 63 characters, using only lowercase
to
to
, and
, and must not start with
Complete the
network configuration
for the newly installed environment. That may include installing suitable
network management
software, configuring it if necessary and enabling its systemd unit so that it starts at boot.
Initramfs
Creating a new
initramfs
is usually not required, because
mkinitcpio
was run on installation of the
kernel
package with
pacstrap
For
LVM
system encryption
or
RAID
, modify
mkinitcpio.conf(5)
and recreate the initramfs image. If you have
changed the default console keymap
, only recreating the initramfs is required:
# mkinitcpio -P
Root password
Set a secure
password
for the
root user
to allow performing administrative actions:
# passwd
Boot loader
Choose a boot loader applicable to your partitioning scheme and install it. See the explanations and the comparison table in
Arch boot process#Boot loader
to make your choice, then follow the installation instructions on its dedicated page.
Reboot
Exit the chroot environment by typing
exit
or pressing
Ctrl+d
Optionally manually unmount all the partitions with
umount -R /mnt
: this allows noticing any "busy" partitions, and finding the cause with
fuser(1)
Finally, restart the machine by typing
reboot
: any partitions still mounted will be automatically unmounted by
systemd
. Remember to remove the installation medium and then login into the new system with the root account.
Post-installation
See
General recommendations
for system management directions and post-installation tutorials (like creating unprivileged user accounts, setting up a graphical user interface, sound or a touchpad).
For a list of applications that may be of interest, see
List of applications
Retrieved from "
Category
Installation process
Installation guide
Add topic