Skip to content

Latest commit

 

History

History
151 lines (118 loc) · 4.38 KB

README.md

File metadata and controls

151 lines (118 loc) · 4.38 KB

project_automation

K8s with CRI-O by Ansible on RPi 4 - A project for learning Ansible and Kubernetes

Motivation

I'm interested in Ansible and Kubernetes and want to learn to use them.

The plan is to use one RPi as a control node with ansible installed and a 2,5" USB HDD attached as external mass storage.

3 additional RPi will be used as one master and two worker nodes. All RPi are connected to a PoE switch so I can poweron/poweroff the three RPi 4 externally.

Because of network boot for the three RPi 4 the plugged-in SD-Card is used as mass-storage for K8s with GlusterFS installed.

The whole environment is seperated by a VLAN at the pfSense Firewall.

Setup

Hardware

  • 1x Raspberry Pi 3 Modell B - control
    • 1x Seagate BarraCuda Pro Compute 500GB - external storage
  • 3x Raspberry Pi 4 Modell B, 4GB RAM - master & worker
    • 4x SanDisk Extreme Plus R170/W90 microSDXC 128GB Kit, UHS-I U3, A2, Class 10
  • 1x Ubiquiti UniFi US-8-60W - PoE Switch
  • 1x Zotac ZBOX CI327 - Firewall

Network layout

home-lab

Software

Raspberry Pi 3 - 1x control Node

  • OS: Raspbian Lite
  • Additional Packages:
    • ansible
    • python-argcomplete
    • git
    • sshpass

Raspberry Pi 4 - 1x master Node, 2x worker Node

  • OS: Raspbian Lite

Zotac ZBOX CI327 - Firewall

  • OS: pfSense

Preparation - pre ansible phase

Installing all Raspberry Pi

Preparing the control node - short

You can find a detailed description here

  • update the firmware and upgrade all installed packages
  • install the packages:
    • ansible
    • python-argcomplete
    • git
    • sshpass
  • activate python-argcomplete and reboot
  • create the folder /ext/repo
  • clone the project into /ext/repo/project_automation

Preparing the master & worker nodes - short

You can find a detailed description here

  • update the firmware and upgrade all installed packages
  • enable network boot

Ansible phase

  • switch into cloned repository folder
cd /ext/repo/project_automation

control node

Common, user and ssh configuration

sudo ansible-playbook -i inventory control.yml --tags "install"
  • reboot
sudo reboot
  • login as new created user
  • run playbook control.yml with tag install
sudo ansible-playbook -i inventory control.yml --tags "install"

Install and configure gitea

  • for detailed informations see role:

  • run playbook control.yml with tag gitea

sudo ansible-playbook -i inventory control.yml --tags "gitea"

Install and confiure network boot for nodes

  • for detailed informations see role:

  • run playbook control.yml with tag pxe

sudo ansible-playbook -i inventory control.yml --tags "pxe"

master & worker nodes

Updating nodes

  • for detailed informations see role:

  • run playbook nodes.yml with tag update

ansible-playbook -i inventory nodes.yml --tags "update" -u pi --ask-pass --become

Common, user and ssh configuration

ansible-playbook -i inventory nodes.yml --tags "install"

Install and configre glusterfs

  • for detailed informations see roles:

  • run playbook nodes.yml with tag gluster

ansible-playbook -i inventory nodes.yml -u steled --tags "gluster"