You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

164 lines
4.5 KiB
Markdown

4 years ago
# Arch Linux installation to serve as a docker host
###### guide by example
![logo](https://i.imgur.com/SkENpGn.png)
# Purpose
Linux that will run docker.
This is not a very hand holding guide.</br>
Google for plenty of tutorials and youtube videos alongside arch wiki.
* [Official site](https://www.archlinux.org/)
* [Arch wiki install guide](https://wiki.archlinux.org/index.php/installation_guide)
* [Arch wiki docker entry](https://wiki.archlinux.org/index.php/docker)
# Files and directory structure
```
/home/
└── bastard/
└── docker/
├── container-setup #1
├── container-setup #2
├── ...
```
# Make installation usb
* [wiki](https://wiki.archlinux.org/index.php/USB_flash_installation_media)
`sudo dd bs=4M if=archlinux-2020.05.01-x86_64.iso of=/dev/sdX status=progress oflag=direct`
The above command will fuck your machine up if you dunno what you are doing
# Boot from the usb
4 years ago
This is BIOS/MBR setup as I am running on an old thinkpad with a busted screen,
4 years ago
plus I like the simplicity of it.</br>
So if theres boot menu option choose non-uefi.
# Installation
* create a single partition and mark it bootable</br>
`cfdisk /dev/sda`
* build ext4 filesystem on it</br>
`mkfs.ext4 /dev/sda1`
* mount the new partition</br>
`mount /dev/sda1 /mnt`
* choose geographicly close mirror, ctrl+k deletes a line in nano</br>
`nano /etc/pacman.d/mirrorlist`
* install the base system </br>
4 years ago
`pacstrap /mnt base linux linux-firmware base-devel grub dhcpcd nano`
4 years ago
* gnerate fstab</br>
`genfstab -U /mnt > /mnt/etc/fstab`
* chroot in to the new system</br>
`arch-chroot /mnt`
* install grub</br>
`grub-install /dev/sda`</br>
`grub-mkconfig -o /boot/grub/grub.cfg`
* remove the bootable media and restart the machine</br>
`exit`</br>
`reboot`
# Basic configuration after the first boot
* login as `root`</br>
* set password for root</br>
`passwd`
* set hostname</br>
`echo docker-host > /etc/hostname`
* add new user and set their password</br>
`useradd -m -G wheel bastard`
`passwd bastard`
* edit sudoers to allow users group wheel to sudo</br>
`EDITOR=nano visudo`</br>
*%wheel ALL=(ALL) ALL*
* check the network interface name</br>
`ip link`
* enable aquiring dynamic IP</br>
`systemctl enable --now dhcpcd@enp0s25`
* uncomment desidred locales in locale.gen</br>
`nano /etc/locale.gen`</br>
* generate new locales and set one system wide</br>
`locale-gen`</br>
`localectl set-locale LANG=en_US.UTF-8`
* select timezone and set it permanent</br>
`tzselect`</br>
`timedatectl set-timezone 'Europe/Bratislava'`
* set hardware clock and sync using ntp</br>
`hwclock --systohc --utc`</br>
`timedatectl set-ntp true`
* setup a swap file</br>
`fallocate -l 8G /swapfile`</br>
`chmod 600 /swapfile`</br>
`mkswap /swapfile`</br>
`nano /etc/fstab`</br>
*/swapfile none swap defaults 0 0*
* enable colors in pacman.conf</br>
`nano /etc/pacman.conf`
*Color*
* reboot</br>
`reboot`
4 years ago
# SSH, ZSH, Docker, and other goodies
4 years ago
4 years ago
From now on its login as non-root user.
4 years ago
### Setup SSH access
4 years ago
* install openssh package</br>
4 years ago
`sudo pacman -S openssh`
4 years ago
* edit sshd_config</br>
4 years ago
`sudo nano /etc/ssh/sshd_config`</br>
4 years ago
*PermitRootLogin prohibit-password*</br>
*PasswordAuthentication yes*
* enable sshd service</br>
`sudo systemctl enable --now sshd`
4 years ago
### ZSH shell
4 years ago
I like [Zim](https://github.com/zimfw/zimfw),
it's the fastest zsh framework and out of the box setup nicely
4 years ago
4 years ago
* install zsh package</br>
`sudo pacman -S zsh`
4 years ago
* change users default shell to zsh</br>
4 years ago
`chsh -s /bin/zsh`</br>
4 years ago
`curl -fsSL https://raw.githubusercontent.com/zimfw/install/master/install.zsh | zsh`
4 years ago
### Setup docker
4 years ago
4 years ago
* have `docker` and `docker-compose` packages installed</br>
`sudo pacman -S docker docker-compose`
* enable docker service</br>
`sudo systemctl enable --now docker`
* add non-root user to the docker group</br>
`sudo gpasswd -a bastard docker`
4 years ago
4 years ago
### Extra stuff
4 years ago
4 years ago
* `sudo pacman -S vim git cronie curl borg htop lm_sensors nnn bind-tools`
4 years ago
* install yay for access to AUR packages</br>
`git clone https://aur.archlinux.org/yay-bin.git`</br>
`cd yay-bin && makepkg -si`</br>
`cd .. && rm -rf yay-bin`</br>
4 years ago
4 years ago
`ctop` and `inxi` are good packages from yay
4 years ago
### Adding stuff to .zshrc
* `export EDITOR=vim`
* for ctrl+f prepending sudo
```bash
add_sudo (){
BUFFER="sudo $BUFFER"
zle -w end-of-line
}
zle -N add_sudo
bindkey "^f" add_sudo
```