A place for users to learn and experiment with Linux distros
This repo provides users a "sandbox" to explore various Linux distros in any version supported by Docker. This is especially useful for
- WSL users who only have access to distros provided on the Windows store, but have Docker installed.
- Users who want to experiment with different Linux supported file systems like EXT3 and XFS with distros like Arch Linux before commiting to one on personal or production server(s).
- Users who want a central location to quickly setup and experiment with a new distro they haven't used before.
-
Docker Swarm support - This feature will spin up containers across different servers with Docker running. Inside the containers will be Linux VMs that have SSH access to other containers running in the swarm. Expected completion: 9/1/2022
-
Shell script collection - Directories for each distro will include shell scripts that users can run and experiment with. Here, users can learn about the different Linux shells. Expected completion: ongoing effort
-
Improved VM versioning - Currently, this repo supports an arbitrary number of VMs (limited only by hardware resources), but one version per distro. For example, users can run one, five, or twenty Alpine VMs, but they must all be the same version. Expected completion: 9/15/2022
-
Improved repository organization - Depending on web traffic and general interest, future updates to this repo will be better organized under the "Projects" section. A guide for submitting PRs will also be provided. Oh, and more a comprehensive install / setup guide Expected completion: ongoing effort
-
Enabling systemctl and/or service - this is a current major limitation, as starting and configuring applications like Redis, postgres, and Docker (yes, you can run Docker inside a Docker container) is not currently supported. Once this is configured, it is possible to make more sophisticated DevOps sandboxes with Docker compose which can be experimented with before an architecture is chosen for production/deployment. Expected completion: 10/15/2022
-
Add all Docker supported Linux images - this is an easy enough task, just slightly tedious. Expected completion: 9/1/2022
This repo assumes Python is installed (obviously 3+) and Docker. Code was written on a Windows 11 laptop and tested with Docker installed on WSL Ubuntu 20.04 LTS, but should work as long as Python and Docker work correctly on host machine (submit an issue if it doesn't). Setup here will assume you are in a Linux terminal. Docker volumes are mounted to each container, containing shell scripts appropriate for each distro. This structure may be reworked in future updates.
There is a JSON-based configuration file, which allows users to switch which version of the Linux distro they want (make sure it matches a tag supported on Docker Hub EXACTLY) and the number of containers (which run a VM of that particular distro + version). Then, a Python file auto-generates a Docker compose YAML file which is used to spin up the containers. Default is one container for each of the supported distros (ten as of 8/10/2022)
And now, for a step-by-step guide
-
git clone https://github.com/Kernel-Dirichlet/linux-cluster-playground.git
- clone this repository -
cd linux-cluster-playground/linux_cluster
- navigate into the directory -
vim default-config.json
ORnano default-config.json
- open the default-config.json file. Here, you can simply change the number of containers you want for each distro and the specific version. -
python3 make_cluster.py
- runs the python script which auto-generates the Docker compose YAML file. -
bash local-config.sh
- This spins up the cluster. Sit back and watch the magic. Bash script sets up and congifures cluster. -
Now, you can just shell your way into any of the containers. Because we spin the containers up with Docker Compose, the containers always have a lovely consistent naming format -
linux_cluster-(distro)-container-(index)
. Below is the full command for each of the distrosI) ALPINE -
sudo docker exec -it linux_cluster-alpine-container-1 sh
II) ARCH LINUX -
sudo docker exec -it linux_cluster-archlinux-container-1 bash
III) CENTOS -
sudo docker exec -it linux_cluster-centos-container-1 bash
IV) CLEAR LINUX -
sudo docker exec -it linux_cluster-clearlinux-container-1 bash
V) DEBIAN -
sudo docker exec -it linux_cluster-debian-container-1 bash
VI) FEDORA -
sudo docker exec -it linux_cluster-fedora-container-1 bash
VII) ORACLE -
sudo docker exec -it linux_cluster-oracle-container-1 bash
VIII) ROCKY LINUX -
sudo docker exec -it linux_cluster-rockylinux-container-1 bash
IX) SUSE LINUX -
sudo docker exec -it linux_cluster-suse-container-1 bash
X) UBUNTU -
sudo docker exec -it linux_cluster-ubuntu-container-1 bash
Now that we know how to actually get inside the containers, we can now run commands, and ultimately, shell scripts. Below are some commands to install basic packages and begin exploring each distro. There is an asterisk * next to some of the update/upgrade commands because there are nuances between how different distros and package managers implement this. This will be documented in future updates to this repo.
I) ALPINE - https://www.alpinelinux.org/
-
install bash:
apk add bash
- adds bash shell capabilities, since Alpine does not come with bash. Once installed, runbash /shell_scripts/hello_alpine.sh
This will display a welcome message with the Alpine version defined in the JSON config file!
- upgrade:
apk upgrade
- update:
apk update
- search packages:
apk search package-name
- installing package:
apk add package-name
II) ARCH LINUX - https://archlinux.org/
- upgrade:
pacman -Syu
- update: *N/A
- search packages: *
pacman -Sy
- installing packages:
pacman -S package-name
- run "hello linux" -
bash /shell_scripts/hello_arch_linux.sh
III) CENTOS - https://www.centos.org/
- upgrade: *N/A
- update:
yum update
- search packages:
yum search package-name
- installing packages:
yum install package-name
- run "hello linux" -
bash /shell_scripts/hello_centos.sh
IV) CLEAR LINUX - https://clearlinux.org/
- upgrade: *there is a command for auto-updating -
swupd autoupdate
- update:
swupd update
- search packages: We need to first run
swupd bundle-add os-core-search
, then we runswupd-search package-name
- installing packages:
swupd bundle-add package-name
- run "hello linux" -
bash /shell_scripts/hello_clear_linux.sh
V) DEBIAN - https://www.debian.org/
- upgrade:
apt upgrade
- update:
apt update
- search packages:
apt search package-name
- installing packages:
apt install package-name
- run "hello linux":
bash /shell_scripts/hello_debian.sh
VI) FEDORA - https://getfedora.org/
- upgrade:
dnf upgrade
- update:
dnf update
- search packages:
dnf search package-name
- installing packages:
dnf install package-name
- run "hello linux":
bash /shell_scripts/hello_fedora.sh
VII) ORACLE - https://www.oracle.com/linux/
- upgrade:
dnf upgrade
- update:
dnf update
- search packages:
dnf search package-name
- installing packages:
dnf install package-name
- run "hello linux":
bash /shell_scripts/hello_oracle.sh
VIII) ROCKY LINUX - https://rockylinux.org/
- upgrade:
dnf upgrade
- update:
dnf update
- search packages:
dnf search package-name
- installing packages:
dnf install package-name
- run "hello linux":
bash /shell_scripts/hello_rocky_linux.sh
IX) SUSE LINUX - https://www.suse.com/
- upgrade:
zypper dist-upgrade
- update:
zypper update
- search packages:
zypper search package-name
- installing packages:
zypper install package-name
- run "hello linux":
bash /shell_scripts/hello_suse_linux.sh
X) UBUNTU - https://ubuntu.com/
- upgrade:
apt updrade
- update:
apt update
- search packages:
apt search package-name
- installing packages:
apt install package-name
- run "hello linux":
bash /shell_scripts/hello_ubuntu.sh