Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lisenet/homelab-ansible
Ansible playbooks to build my KVM-based homelab.
https://github.com/lisenet/homelab-ansible
ansible homelab kubernetes-deployment kvm pxe
Last synced: 3 days ago
JSON representation
Ansible playbooks to build my KVM-based homelab.
- Host: GitHub
- URL: https://github.com/lisenet/homelab-ansible
- Owner: lisenet
- License: bsd-3-clause
- Created: 2022-03-05T02:38:26.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-09-18T09:22:20.000Z (4 months ago)
- Last Synced: 2025-01-02T21:13:33.547Z (24 days ago)
- Topics: ansible, homelab, kubernetes-deployment, kvm, pxe
- Language: Jinja
- Homepage: https://www.lisenet.com/2021/install-a-multi-master-kubernetes-cluster-with-ansible/
- Size: 9.29 MB
- Stars: 48
- Watchers: 2
- Forks: 19
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# homelab-ansible
Ansible infrastructure for my homelab.
[![version](https://img.shields.io/github/manifest-json/v/lisenet/homelab-ansible?label=ansible)](https://github.com/lisenet/homelab-ansible/blob/master/README.md#version-table)
[![python](https://img.shields.io/badge/Python-3.11-blue)](https://github.com/lisenet/homelab-ansible/blob/master/README.md#version-table)
[![license](https://img.shields.io/github/license/lisenet/homelab-ansible)](https://github.com/lisenet/homelab-ansible/blob/master/LICENSE)
[![last commit](https://img.shields.io/github/last-commit/lisenet/homelab-ansible)](https://github.com/lisenet/homelab-ansible/commits/master)
[![commit activity](https://img.shields.io/github/commit-activity/y/lisenet/homelab-ansible)](https://github.com/lisenet/homelab-ansible/commits/master)
[![issues](https://img.shields.io/github/issues/lisenet/homelab-ansible)](https://github.com/lisenet/homelab-ansible/issues)
[![pull_requests_closed](https://img.shields.io/github/issues-pr-closed/lisenet/homelab-ansible)](https://github.com/lisenet/homelab-ansible/pulls)## Version Table
Software versions used by this repository:
| Package | Version |
| -------------- | --------- |
| ansible | 9.3.0 |
| ansible-core | 2.16.4 |
| ansible-lint | 6.22.0 |
| python | 3.11 |## Install Ansible
This repository uses Ansible version that requires Python 3.11.
Install required packages.
Use `apt` for Debian based systems:
```bash
sudo apt install -y python3.11 python3.11-pip
```Use `yum` for Red Hat based systems:
```bash
sudo yum install -y python3.11 python3.11-pip python3.11-netaddr
```Use `pip` in your selected Python environment to install the Ansible package of your choice for the current user:
```bash
TMPDIR="${HOME}/tmp" python3.11 -m pip install --user ansible==9.3.0
```### Optional: Ansible-lint and pre-commit
Ansible Lint is a command-line tool for linting playbooks, roles and collection.
Note that `ansible-core` 2.12+ was made as a direct dependency with Ansible Lint release v6.0.0. This means that when you install the `ansible-lint` package >=v6.0.0, it also installs `ansible-core` and `ansible` packages as dependencies.
Package `yamllint` is installed as a dependency as well.Install packages:
```bash
python3.11 -m pip install --user ansible-lint==6.22.0
```To use Ansible-lint with pre-commit, use the following command to create a pre-commit configuration file:
```bash
cat < .pre-commit-config.yaml
- repo: https://github.com/ansible/ansible-lint
rev: v6.22.0
hooks:
- id: ansible-lint
files: \.(yaml|yml)$
EOF
```Install `pre-commit` package:
```bash
python3.11 -m pip install --user pre-commit==3.3.3
```Enable pre-commit for the git repository:
```bash
pre-commit install
```## Passwordless SSH Authentication
Servers built with Kickstart/Packer have root SSH keys pre-configured. If that is not the case, then see below.
Configure passwordless root SSH authentication from the device where Ansible is installed (e.g. your laptop):
```bash
ssh-copy-id -f -i ./roles/hl.users/files/id_rsa_root.pub [email protected]
```## Set Ansible User Password
Create a file `vault.key` to store your Ansible Vault secret (see `ansible.cfg` for vault_password_file). Use Ansible Vault to create an encrypted file `./roles/hl.users/defaults/secure.yml` to store your user password:
```bash
ansible-vault create ./roles/hl.users/defaults/secure.yml
```The variable for user password is `user_password`.
## Configuration with Ansible
### Configure PXE Hosts
```bash
ansible-playbook ./playbooks/configure-pxe-hosts.yml --extra-vars "download_pxe_boot_media=true download_packer_media=true"
```### Configure KVM Hosts
```bash
ansible-playbook ./playbooks/configure-kvm-hosts.yml
```### Configure Admin Hosts
```bash
ansible-playbook ./playbooks/configure-admin-hosts.yml
```### Configure Kubernetes Hosts
Prepare Kubernetes hosts for cluster deployment:
```bash
ansible-playbook ./playbooks/configure-k8s-hosts.yml
```Configure Kubernetes cluster for the first time:
```bash
ansible-playbook ./playbooks/configure-k8s-cluster.yml
```### Configure OpenVAS Hosts
```bash
ansible-playbook ./playbooks/configure-openvas-hosts.yml
```### Configure Dell Hosts
```bash
ansible-playbook ./playbooks/configure-dell-hosts.yml
```### Optional: Configure Hosts File
This is optional because of the local DNS server:
```bash
ansible-playbook ./playbooks/configure-hostsfile.yml
```### Optional: Configure New Relic Agent
```bash
ansible-playbook ./playbooks/configure-newrelic-hosts.yml
```## Ansible-configured PXE Boot Server
Note that user password for PXE boot Kickstart files is set to `packer`.
![Homelab PXE Boot Menu](./images/homelab-pxe-boot-menu.png)
## Homelab Network Diagram
![Homelab Network Diagram](./images/kubernetes-homelab-diagram.png)