easy arch mirror
Find a file
i-c-u-p 165a2c03f6
Update easy-arch.sh
edited some functions related to user input so that their formatting/installing won't take place until after questions are over to prevent having to wait in between questions. also moved the order of the microcode virt check functions run to prevent installing stuff before questions are over, and some other funcs to just be more convenient (keyboard layout is now selected first incase the user isn't using US qwerty) and now there are options to search for locales and keymaps before making a selection.
2022-04-27 08:23:34 +00:00
.github Update FUNDING.yml 2021-12-27 10:53:19 +01:00
_config.yml Set theme jekyll-theme-cayman 2021-02-01 13:12:01 +01:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2021-12-31 14:29:00 +01:00
easy-arch.sh Update easy-arch.sh 2022-04-27 08:23:34 +00:00
LICENSE Create LICENSE 2021-11-04 18:58:16 +01:00
README.md Update README.md 2022-01-01 10:14:56 +01:00

Introduction

easy-arch is a bash script made in order to boostrap a basic but modern Arch Linux environment, with a few cherry-picked features:

  1. BTRFS bootable snapshots from GRUB
  2. LUKS2 encryption
  3. ZRAM as swap
  4. systemd-oomd
  5. Autodetect VMs and provide guest tools (if available)

How does it work?

  1. Download an Arch Linux ISO from here
  2. Flash the ISO onto an USB Flash Drive
  3. Boot the live environment
  4. Set the keyboard layout by using loadkeys <kblayout>
  5. Connect to the internet
  6. Run this bash <(curl -sL bit.ly/easy-arch)

Partitions layout

Partition Number Label Size Mountpoint Filesystem
1 ESP 512 MiB /boot/ FAT32
2 Cryptroot Rest of the disk / BTRFS Encrypted (LUKS2)

The partitions layout is simple and it's inspired by this section of the Arch Linux Wiki. As you can see there're only two partitions:

  1. A FAT32, 512MiB sized, mounted at /boot/ for the ESP.
  2. A LUKS2 encrypted container, which takes the rest of the disk space, mounted at / for the rootfs.

BTRFS subvolumes layout

Subvolume Number Subvolume Name Mountpoint
1 @ /
2 @home /home
3 @root /root
4 @srv /srv
5 @snapshots /.snapshots
6 @var_log /var/log
7 @var_pkgs /var/cache/pacman/pkg

The BTRFS subvolumes layout follows the traditional and suggested layout used by Snapper, you can find it here. Here's a brief explanation of the BTRFS layout I chose:

  1. @ mounted at /
  2. @home mounted at /home
  3. @root mounted at /root
  4. @srv mounted at /srv
  5. @snapshots mounted at /.snapshots
  6. @var_log mounted at /var/log
  7. @var_pkgs mounted at /var/cache/pacman/pkg