Go to file
2024-09-25 08:55:48 +01:00
configs Update asrock03, maas config for new API, and now use jammy, updaate sysctl configs 2024-09-24 20:14:05 +01:00
examples Update bootstrap-maas, auto calculate node_count 2020-12-30 09:36:48 +00:00
.gitignore Added juju VMs as part of maas-manage-nodes.sh 2020-12-28 17:08:10 +00:00
add_dns_records.sh Add domain, if it doesn't exist 2021-12-25 18:47:41 +00:00
admin-openrc Merged some of Ed Hope-Morley's work into generic novarc 2019-07-10 13:11:10 +00:00
bootstrap-maas.sh Updates with some fine tuning 2022-10-30 19:17:51 +00:00
functions.sh Updates with some fine tuning 2022-10-30 19:17:51 +00:00
manage-hypervisor-nodes.sh Some updates to fix build 2022-11-01 08:16:54 +00:00
manage-vm-nodes.sh Add osinfo attribute to virt-install 2024-09-25 08:55:48 +01:00
README.md Change name of script 2021-03-25 08:28:06 +00:00
reserve_ips.sh Updates with some fine tuning 2022-10-30 19:17:51 +00:00
TODO.md Add option for hypervisor and therefore re-jig read_config 2020-12-30 22:08:49 +00:00
user-data.yaml Update asrock03, maas config for new API, and now use jammy, updaate sysctl configs 2024-09-24 20:14:05 +01:00

MAAS Auto-builder

This is a quick-and-dirty set of shell scripts that will build out and bootstrap a MAAS environment with all of the bits and pieces you need to get it running for any cloud, any workload.

  • manage-vm-nodes.sh.........: Create kvm instances that MAAS will manage
  • manage-hypervisor-nodes.sh.: Create hypervisors that MAAS will manage
  • bootstrap-maas.sh..........: Build and bootstrap your MAAS environment
  • functions.sh...............: Common function that the first 2 scripts use
  • user-data.yaml.............: cloud-init for hypervisor nodes

There are plenty of options to customize its behavior, as well as drop in to any step of the process without rebuilding the full MAAS from scratch.

Requirements

Requires, minimally, bash, jq and a working Ubuntu environment. This has not been tested on CentOS or Debian, but should work minimally on those environments, if you choose to make that your host. Patches are welcome, of course.

Components - bootstrap-maas.sh

  -a <cloud_name>    Do EVERYTHING (maas, juju cloud, juju bootstrap)
  -b                 Build out and bootstrap a new MAAS
  -c <cloud_name>    Add a new cloud + credentials
  -i                 Just install the dependencies and exit
  -j <name>          Bootstrap the Juju controller called <name>
  -n                 Create MAAS kvm nodes (to be imported into chassis)
  -r                 Remove the entire MAAS server + dependencies
  -t <cloud_name>    Tear down the cloud named <cloud_name>

Components - manage-hypervisor-nodes.sh

  -a <node>   Create and Deploy
  -c <node>   Creates Hypervisor
  -d <node>   Deploy Hypervisor
  -k <node>   Add Hypervisor as Pod
  -n <node>   Assign Networks
  -p <node>   Update Partitioning
  -w <node>   Removes Hypervisor

Components - manage-maas-nodes.sh

  -c    Creates everything
  -w    Removes everything
  -d    Releases VMs, Clears Disk
  -n    Updates all the networks on all VMs
  -r    Recommission all VMs
  -j    Only create juju VM
  -z    Adds the machines to their respective zones

Misc - functions.sh

Many functions that are common between the 2 scripts above

Misc - user-data.yaml

cloud-init file, that helps with deployment of the hypervisors. This helps to automate the deployment of the hypervisor, which in turns grabs this repo and deploys all the VMs required.

Installing and testing MAAS

Just run ./bootstrap-maas.sh with the appropriate option above. Minimally, you'll want to use ./bootstrap-maas.sh -b or -i to install just the components needed.

I've done all the work needed to make this as idempotent as possible. It will need some minor tweaks to get working with MAAS 2.4.x, because of the newer PostgreSQL dependencies.