Pre-installation
Download and boot the installation medium. You will have to log in as artix user with password artix, and presented with a Zsh shell prompt. You can access to root user with su command.
To switch to a different console—for example, to view this guide with ELinks alongside the installation—use the Alt+arrow shortcut. To edit configuration files, nano, vi and vim are available.
Set the keyboard layout
The default console keymap is US. To list available layouts, run ls /usr/share/kbd/keymaps/**/*.map.gz. To modify the layout, append a corresponding file name to loadkeys(1), omitting path and file extension. For example, run loadkeys de-latin1 to set a German keyboard layout.
Console fonts are located in /usr/share/kbd/consolefonts/ and can likewise be set with setfont(8).
Verify the boot mode
If UEFI mode is enabled on an UEFI motherboard, Artix ISO will boot Artix Linux accordingly via GRUB. To verify this, list the efivars directory:
# ls /sys/firmware/efi/efivars
If the directory does not exist, the system may be booted in BIOS or CSM mode. Refer to your motherboard's manual for details.
Connect to the Internet
The installation image enables the dhcpcd daemon on boot for wired network devices. The connection may be checked with:
# ping archlinux.org
If no connection is available, stop the dhcpcd service with rc-service dhcpcd stop, and see Network configuration.
For wireless connections, iw(8), wpa_supplicant(8) are available. See Wireless network configuration.
Update the system clock
Use ntpd(1) to ensure the system clock is accurate:
# pacman -S ntp
# ntpd -qg
Partition the disks
When recognized by the live system, disks are assigned to a block device such as /dev/sda. To identify these devices, use lsblk or fdisk — results ending in rom, loop or airoot may be ignored:
# fdisk -l
The following ''partitions'' (shown with a numerical suffix) are required for a chosen device:
Swap space can be set on a separate partition or a swap file.
To modify partition tables, use fdisk or parted. See Partitioning for more information.
If you want to create any stacked block devices for LVM, disk encryption or RAID, do it now.
Format the partitions
Once the partitions have been created, each must be formatted with an appropriate file system. For example, to format the root partition on /dev/sda1 with ext4, run:
# mkfs.ext4 /dev/sda1
See File systems#Create a file system for details.
Mount the file systems
Mount the file system on the root partition to /mnt, for example:
# mount /dev/sda1 /mnt
Create mount points for any remaining partitions and mount them accordingly, for example:
# mkdir /mnt/boot
# mount /dev/sda2 /mnt/boot
fstabgen 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 for Artix repositories and in /etc/pacman.d/mirrorlist-arch for Archlinux repositories. On the live system, all Archlinux mirrors are enabled, and sorted by their synchronization status and speed at the time the installation image was created.
The higher a mirror is placed in the list, the more priority it is given when downloading a package. You may want to edit the file accordingly, and move the geographically closest mirrors to the top of the list, although other criteria should be taken into account.
This file will later be copied to the new system by basestrap, so it is worth getting right.
Install the base packages
First fix an issue on basestrap as following:
# sed -e 's/${hostcache} && pacman/${hostcache} || pacman/g' -e 's/${interactive} && pacman/${interactive} || pacman/g' -i /usr/bin/basestrap
Use the basestrap script to install the base package group:
# basestrap -i /mnt base openrc-system openrc-world systemd-dummy libsystemd-dummy
This group does not include all tools from the live installation, such as btrfs-progs or specific wireless firmware; see import.list.d for comparison.
To install packages and other groups such as base-devel, append the names to basestrap (space separated) or to individual pacman commands after the Chroot step.
Configure the system
Fstab
Generate an fstab file (use -U or -L to define by UUID or labels, respectively):
# fstabgen -U /mnt >> /mnt/etc/fstab
Check the resulting file in /mnt/etc/fstab afterwards, and edit it in case of errors.
Chroot
Change root into the new system:
# artools-chroot /mnt
Time zone
Set the time zone:
# ln -sf /usr/share/zoneinfo/Region/City /etc/localtime
Run hwclock(8) to generate /etc/adjtime:
# hwclock --systohc
This command assumes the hardware clock is set to UTC. See Time#Time standard for details.
Locale
Uncomment en_US.UTF-8 UTF-8 and other needed localizations in /etc/locale.gen, and generate them with:
# locale-gen
Set the LANG variable in locale.conf(5) accordingly, for example:
#/etc/locale.conf
LANG=en_US.UTF-8
If you set the keyboard layout, make the changes persistent in /etc/conf.d/keymaps:
#/etc/conf.d/keymaps
keymap="de-latin1"
Hostname
Add the hostname to /etc/conf.d/hostname:
#/etc/conf.d/hostname
hostname="myhostname"
Consider adding a matching entry to hosts(5):
#/etc/hosts
127.0.0.1 localhost.localdomain localhost
::1 localhost.localdomain localhost
127.0.1.1 myhostname.localdomain myhostname
See also Network configuration#Set the hostname.
Init scripts
Enable the needed following init scripts:
rc-update add udev boot
rc-update add elogind boot
rc-update add dbus default
Network configuration
The newly installed environment has no network connection activated by default. See Network configuration#Network managers.
For Wireless configuration, install the iw and wpa_supplicant packages, as well as needed firmware packages. Optionally install dialog for usage of wifi-menu.
Initramfs
Creating a new initramfs is usually not required, because mkinitcpio was run on installation of the linux-lts package with basestrap.
For special configurations, modify the mkinitcpio.conf(5) file and recreate the initramfs image:
# mkinitcpio -p linux-lts
Root password
Set the root password:
# passwd
Boot loader
See Category:Boot loaders for available choices and configurations.
If you have an Intel CPU, install the intel-ucode package in addition, and enable microcode updates.
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 eudev. Remember to remove the installation media 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 setting up a graphical user interface, sound or a touchpad).
For a list of applications that may be of interest, see List of applications.