Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mborne/vagrantbox

[DEV] Vagrant helper to create some local VM to play with distributed systems like K3S.
https://github.com/mborne/vagrantbox

ansible dev k3s-cluster vagrant

Last synced: 3 months ago
JSON representation

[DEV] Vagrant helper to create some local VM to play with distributed systems like K3S.

Awesome Lists containing this project

README

        

# vagrantbox

Create some virtual machines with [Vagrant](https://developer.hashicorp.com/vagrant) and [Ansible](https://docs.ansible.com/).

## Motivation

This repository aims at providing a playground :

* To install distributed systems like [K3S](https://github.com/mborne/k3s-deploy#k3s-deploy)
* To illustre the use of Vagrant and Ansible in [mborne/cours-devops (French)](https://github.com/mborne/cours-devops#readme)

## Requirements

* [VirtualBox](https://www.virtualbox.org/wiki/Downloads) or [KVM](https://github.com/mborne/toolbox/tree/master/kvm#readme)
* [Vagrant](https://developer.hashicorp.com/vagrant/install)
* [Ansible](https://docs.ansible.com/ansible/latest/installation_guide/installation_distros.html#installing-ansible-on-ubuntu) if you want to use helper playbooks
* Optional (http proxy) : `vagrant plugin install vagrant-proxyconf` to forward `HTTP_PROXY`, `HTTPS_PROXY` and `NO_PROXY`.

## Parameters

See supported env vars in [Vagrantfile](Vagrantfile) :

| Name | Description | Default value |
| ---------------------- | ----------------------------------------------------------------------- | ------------------ |
| `VAGRANTBOX_BOX` | Base image from [Vagrant Cloud](https://app.vagrantup.com/boxes/search) | `"ubuntu/jammy64"` |
| `VAGRANTBOX_NUM_NODES` | Number of VM | `4` |
| `VAGRANTBOX_NETWORK` | Network for VM | `"192.168.50"` |
| `VAGRANTBOX_MEMORY` | VM memory in Mo | `"2048"` |

## Usage

### Vagrant

| Description | Command |
| ------------------------- | ----------------------------------------------------------------- |
| Start VMs with VirtualBox | `vagrant up` |
| Start VMs with KVM | `VAGRANTBOX_BOX=generic/ubuntu2204 vagrant up --provider=libvirt` |
| Check VM status | `vagrant status` |
| Open a terminal in a VM | `vagrant ssh vagrantbox-1` |
| Destroy VMs | `vagrant destroy -f` |

> see also [gist.github.com - wpscholar/vagrant-cheat-sheet.md](https://gist.github.com/wpscholar/a49594e2e2b918f4d0c4#file-vagrant-cheat-sheet-md)

### Ansible

The following playbooks are available to configure guest and VMs :

| Name | Description |
| ------------------------------------------------------------ | ---------------------------------------------------------------- |
| [playbooks/quickstart.yml](playbooks/quickstart.yml) | Apply the following playbooks |
| [playbooks/configure-vm.yml](playbooks/configure-vm.yml) | Add `~/.ssh/id_rsa.pub` and fill `/etc/hosts` on each VM |
| [playbooks/clear-ssh.yml](playbooks/clear-ssh.yml) | Update `~/.ssh/known_hosts` with SSH keys for the vagrantbox VMs |
| [playbooks/upgrade.yml](playbooks/upgrade.yml) | Upgrade system package (`apt-get update && apt-get upgrade -y`) |
| [playbooks/configure-host.yml](playbooks/configure-host.yml) | Fill `/etc/hosts` on VM's host (**optional**, see bellow) |

You may use [playbooks/quickstart.yml](playbooks/quick-start.yml) as follow :

```bash
# /etc/hosts edition requires sudo
ansible-playbook -i inventory playbooks/quickstart.yml --ask-become-pass
# To avoid sudo requirement, disable changes on /etc/hosts :
ansible-playbook -i inventory playbooks/quickstart.yml -e configure_host_enabled=false
# With KVM and generic/ubuntu2204 :
ansible-playbook -i inventory playbooks/quickstart.yml -e vagrant_provider=libvirt -e ansible_ssh_pass=vagrant --ask-become-pass
```

You should see something like this :

[![asciicast](https://asciinema.org/a/664079.svg)](https://asciinema.org/a/664079)

## License

[MIT](LICENSE)

## Ressources

* [Using vagrantbox on windows](docs/windows.md)