Tutorial: Bootstrapping MAAS

Errors or typos? Topics missing? Hard to read? Let us know.

MAAS simplifies hardware management in data centres and clouds, offering scalable deployment. This tutorial will take you through a typical MAAS usage scenario.

Prerequisites

  • Hardware meeting minimum requirements.
  • Knowledge of Ubuntu and basic Linux commands.
  • Understanding of networking concepts.
  • An Ubuntu server with internet access.
  • Administrative rights for setup.

Installation

  1. Update and install dependencies:
   sudo apt update
   sudo apt install snapd lxd lxd-client python3-lxc python3-openstackclient
  1. Install MAAS:
   sudo snap install maas
  1. Install and configure PostgreSQL for MAAS:
   sudo apt install postgresql postgresql-contrib
   sudo su - postgres
   psql
   CREATE USER maas WITH PASSWORD 'password';
   CREATE DATABASE maasdb OWNER maas;
   \q
   exit
  1. Edit /etc/postgresql/12/main/pg_hba.conf, adding a line like the following, to allow the MAAS user to connect:
    sudo vi /etc/postgresql/12/main/pg_hba.conf
    host    maasdb    maas    0/0     md5
  1. Initialise MAAS:
   sudo maas init region+rack --database-uri postgres://maas:password@localhost/maasdb
  1. Make a note of the URL this command returns (similar to the following); you’ll need it later:
    http://<ip-address>:5240/MAAS
  1. Visit the web UI at the noted URL and create an admin account; note that the email address can be anything:
	sudo maas createadmin

MAAS is now installed.

Configuration

  1. Access MAAS at this address, where $API_HOST is the MAAS URL:
    http://${API_HOST}:5240/MAAS

Log in by using the login information you created when initialising MAAS.

  1. In the web UI, go to Settings > General and set a forward DNS server, such as “8.8.8.8”.

  2. Under Images, select the Ubuntu release to sync; you can usually accept the default.

  3. Under Accounts, import your SSH public key from Launchpad or GitHub, or upload your existing public key. Follow the on-screen instructions.

  4. Review remaining configuration options (proxy usage, NTP, and so on).

MAAS can now manage and provision nodes.

Network and DHCP configuration

  1. Identify the LXD bridge IP address:
    ip addr show lxdbr0
  1. In MAAS, go to Subnets and identify the VLAN for that subnet.

  2. Select the VLAN and configure DHCP with the bridge IP as the gateway.

MAAS now provides networking and DHCP for provisioning LXD virtual machines.

Set up LXD

  1. Install the LXD snap:
    sudo snap install lxd
  1. Initialise the LXD configuration:
    sudo lxd init
Choose appropriate options for networking, storage pools, and so on.
  1. Disable LXD’s built-in DHCP server:
    lxc network set lxdbr0 ipv4.dhcp=false 

Create a VM host

Create a LXD VM host with a MAAS-generated certificate:

  1. Select KVM > LXD > Add KVM.

  2. Enter a Name for the KVM host.

  3. Optionally, select a non-default Zone.

  4. Optionally, select a non-default Resource pool.

  5. Enter the LXD address as the gateway address of the bridge for that LXD instance. For example, if lxdbr0 has address 10.4.241.0, the default gateway address is 10.4.241.1.

  6. Select Generate new certificate.

  7. Select Next.

  8. Select Add trust to LXD via command line.

  9. Copy the bash command and certificate from the text box.

  10. In a terminal, paste the copied command and make sure that it runs.

  11. Select Check authentication. You’ll switch screens; if all goes well, you’ll see Connected with a green check-mark.

  12. Select Add new project or Select existing project. Be aware that if you select an existing project, any virtual machines already in that project will begin to commission.

  13. Select Next. You will drop out to a dashboard for the VM host.

MAAS now has a VM host which can support LXD virtual machines.

Add a LXD VM

Add a virtual machine from the MAAS UI:

  1. Select KVM > LXD > desired VM host > Add VM.

  2. Optionally enter the VM name.

  3. Select Use any available core(s) or Pin VM to specific core(s), as needed. Enter specific core identities as appropriate.

  4. Enter the RAM required.

  5. Select Show advanced if you want to edit the Domain, Zone, Resource pool, or Architecture. Make those changes as needed.

  6. Optionally Define interfaces.

  7. Optionally Add disks.

  8. Select Compose machine to create the virtual machine.

You can switch from here to the Machine list to watch the commissioning process in action.

Acquire the VM

To acquire (or allocate) your new machine so that only you can deploy it, select your new VM when “Ready” > Take action > Allocate > confirm. MAAS is now ready to deploy your newly-created virtual machine.

Deploy the VM

To deploy your VM directly from MAAS with the default options, select your allocated VM > Deploy > Deploy. The VM’s status will change several times as MAAS steps through the process. When done, the status becomes the name of the deployed operating system (e.g. ‘Ubuntu 18.04 LTS’).

After deployment

SSH into deployed machines with username Ubuntu. Feel free to explore the deployed VM.

Further learning

Dive deeper into MAAS features and in the explanation, how-to guides, and reference sections.

This topic was automatically closed 365 days after the last reply. New replies are no longer allowed.

The process for generating an encrypted password doesn’t match the example “CREATE USER” command provided. That command presumes an MD5 password hash, but the example encrypted password command provided uses SHA512 instead. Someone who doesn’t notice this may end up stuck here.

It also seems like the procedure is very similar to that in the howto section, although the howto section uses bash variables to set things up and doesn’t rely on md5 hashing. Reference: https://maas.io/docs/how-to-do-a-fresh-install-of-maas#heading--init-maas-production-3-3

Should these two similar sections be brought into alignment?

Hi, I noticed that this tutorial says to install LXD using the debian package.

sudo apt install [...] lxd lxd-client [...]

From the debian package page for LXD:

It is very unlikely that newer versions of LXD will be available in Debian.

The correct way to install LXD should thus be using the snap package.

sudo snap install lxd