mikeletux / sumaform

Terraform configuration to quickly set up SUSE Manager/Uyuni environments

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

sumaform logo

sumaform is a way to quickly configure test Uyuni and SUSE Manager infrastructures with clients and servers.

CI validation tests Join the chat at https://gitter.im/sumaform/Lobby

Installation

Terraform version: 1.0.10

Libvirt provider version: 0.6.3

NOTE: to deploy development versions of SUSE Manager you will have to have SUSE's internal CA certificates installed on your system.

You will need to edit HCL (HashiCorp Configuration Language) files. Syntax highlighting is available in major text editors like atom.

Prerequisites for openSUSE and SUSE Linux Enterprise Server

Execute the following on openSUSE and SUSE Linux Enterprise Server:

# Uncomment one of the following lines depending on your distro

#sudo zypper addrepo http://download.opensuse.org/repositories/systemsmanagement:/sumaform/openSUSE_Tumbleweed/systemsmanagement:sumaform.repo
#sudo zypper addrepo http://download.opensuse.org/repositories/systemsmanagement:/sumaform/openSUSE_Leap_15.2/systemsmanagement:sumaform.repo
#sudo zypper addrepo http://download.opensuse.org/repositories/systemsmanagement:/sumaform/openSUSE_Leap_15.3/systemsmanagement:sumaform.repo
#sudo zypper addrepo http://download.opensuse.org/repositories/systemsmanagement:/sumaform/SLE_12_SP5/systemsmanagement:sumaform.repo
#sudo zypper addrepo http://download.opensuse.org/repositories/systemsmanagement:/sumaform/SLE_15_SP3/systemsmanagement:sumaform.repo

sudo zypper install git-core
sudo zypper install --from systemsmanagement_sumaform terraform terraform-provider-libvirt
git clone https://github.com/uyuni-project/sumaform.git

Prerequisites for Ubuntu and Debian

Execute the following commands:

sudo apt install alien
wget http://download.opensuse.org/repositories/systemsmanagement:/sumaform/SLE_15_SP1/x86_64/terraform.rpm
sudo alien -i terraform.rpm
wget http://download.opensuse.org/repositories/systemsmanagement:/sumaform/SLE_15_SP1/x86_64/terraform-provider-libvirt.rpm
sudo alien -i terraform-provider-libvirt.rpm
git clone https://github.com/uyuni-project/sumaform.git

Backend choice

sumaform can deploy virtual machines to:

  • single libvirt hosts
  • Amazon Web Services
  • null backend

The simplest, recommended setup is to use libvirt on your local host. That needs at least 8 GB of RAM in your machine. If you need a lot of VMs or lack hardware you probably want to use an external libvirt host with bridged networking.

If you use the libvirt provider, install and enable libvirt before you attempt to run the terraform deployment. The virt-manager package is recommended because it configures default resources that the terraform deployment uses, e.g. the default virtual network.

# Download and install libvirt and virt-manager, for example:
sudo zypper install libvirt virt-manager
# On Ubuntu/Debian:
sudo apt install virt-manager qemu-kvm libvirt-daemon-system

# Start libvirt
sudo systemctl start libvirtd

# Optionally, enable libvirt so that it starts at boot time
sudo systemctl enable libvirtd

The Amazon Web Services backend is currently under maintenance and is not immediately usable as-is. We plan to restore it soon.

The null backend can be useful in a wide variety of scenarios, for example:

  • Test configurations before going live in another supported backend
  • Cases in which the virtual infrastructure is outside of the Terraform user's control
  • Cover architectures that will maybe never be covered by any other Terraform plugin

See TROUBLESHOOTING.md for more information about configuring the backend. Each backend has a README file with further configuration instructions.

Basic main.tf configuration

In sumaform you define a set of virtual machines in a main.tf configuration file, then run Terraform to have them deployed. Contents of the file vary slightly depending on the backend you choose.

To choose the backend in use one should create a symbolic link to a backend_module module. Refer to the specific READMEs to get started:

Typical use

Refer to the official guides for a general understanding of Terraform and full commands.

For a very quick start:

vim main.tf     # change your VM setup
terraform init  # populate modules
terraform validate # check if the configuration is valid
terraform apply # prepare and apply a plan to create your systems (after manual confirmation)

Common Variables

cc_username/cc_password: Credentials for the SUSE Customer Center. Set the credentials if you are deploying SUMA, or synchronizing SUMA repositories.

images: In the base module, the images variable specifies the images that you want to download and use in your installation, for example:

# main.tf file contents
module "base" {
  source = "./modules/base"

  ssh_key_path = "/home/user/.ssh/id_ed25519.pub"

  cc_username = "..."
  cc_password = "..."
  images = [
    "centos7o",
    "almalinux8o",
    "opensuse154o",
    "opensuse155o",
    "sles15sp4o",
    "sles15sp5o",
    "sles12sp5o",
    "ubuntu2004o",
    "ubuntu2204o"
  ]
# ...
}

Advanced use

I have a problem!

Check TROUBLESHOOTING.md first, if that does not help feel free to join the Gitter chat or directly drop a line to moio at suse dot de!

About

Terraform configuration to quickly set up SUSE Manager/Uyuni environments

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:HCL 49.2%Language:SaltStack 39.9%Language:Shell 6.2%Language:Python 2.8%Language:XSLT 1.2%Language:Ruby 0.4%Language:Groovy 0.2%