Skip to content

kiemlicz/ambassador

Repository files navigation

Ambassador

Build status

Automated netboot&provisioning server, Foreman and Salt based.

Rationale

Any setup takes time, practically it is never one-time action.
Maintaining multi-node environments is cumbersome (configuration synchronization, duplicated installation process). Sometimes it would also be useful to keep your favourite os hacks/tips/tricks in structured manner (like in some configuration management solution) Moreover updates sometimes break, anything breaks at some point - then it may be better to wipe everything/some part out and start over. Unfortunately as some setup work had already been done such solution may be too radical.

Setup any environment: dev, prod, work, home using Salt and PXE booting (the Foreman's).

Will aim to be both Linux&Windows friendly.

Setup

As the best way of documenting things is writing automation scripts, this automation server's installation process is also automated.
The "installation" process ends up with LXC container containing foreman&salt fully setup and configured.
Simply follow:

  1. git clone https://github.com/kiemlicz/ambassador.git
  2. Optionally provide ambassador-installer.override.conf to override any Salt masterless settings, e.g. add your own pillar:
ext_pillar:
  - git:
    - branch [email protected]:someone/pillar_repo.git:
      - root: pillar
      - env: base
  1. sudo apt install lxc bridge-utils debootstrap python3-lxc
  2. sudo SHELL=/bin/bash python3 installer/install.py --to lxc --name ambassador --ifc [ifc] [--kdbx the.db.kdbx] [--kdbx-pass thepassword] [--kdbx-key the.key] [--secrets https://secrets.server.com/path]

Since foreman still doesn't support 'dockerized' deployment (cannot specify plugins for Foreman Docker images, no official foreman-proxy image).
The provided docker-compose.yml can be used only to setup external DB or any other services. Use docker-compose.override.yml for any overrides:

version: '3'

services:
  db:
    environment:
      - POSTGRES_PASSWORD=realforemanpassword
    volumes:
      - db:/var/lib/postgresql/data

volumes:
  db:
    driver: local
    driver_opts:
      type: none
      o: bind
      device: /tmp/foreman

Documentation

Foreman&Salt workflow is best depicted using this (Foreman's) diagram:

For State Tree and custom extensions documentation, find the State's Tree README.md

Known problems

Provisioning of OSes involves many technologies and tools, it is very likely that something may not always works "as expected"

  1. Many BIOS/UEFI TFTP clients are of very low quality and fail on option negotiation. Thus it may be needed to disable negotiation for some options like blksize. Example for tftp-hpa server: /etc/default/tftpd-hpa append:
    TFTP_OPTIONS="--secure --refuse blksize"

Links&References

Tech stack manuals

Syslinux loaders

Debian netboot images

Debian preseeding

General

  1. https://wiki.debian.org/PXEBootInstall