Skip to content

sei-noconnor/crucible-appliance

Repository files navigation

Crucible Appliance

This repository contains the configuration and scripts needed to build a Crucible virtual appliance in OVF format. The Crucible Appliance is a portable, easily deployable solution designed for secure, efficient, and offline-capable deployments in a vSphere environment.

Table of Contents

  1. Features
  2. Prerequisites
  3. Getting Started
  4. Build
  5. Makefile Documentation
  6. Usage
  7. Contributing
  8. License

Features

  • SSO Authentication (Keycloak): Secure and centralized authentication across all services within the appliance, simplifying user management.
  • Git Server (Gitea): Embedded Gitea server for streamlined in-cluster version control and collaboration.
  • Cert-Manager: Automates certificate management, including the use of a "crucible.local" root CA, ensuring secure communication.
  • CI/CD (ArgoCD): Enables continuous integration and continuous deployment with ArgoCD for seamless application updates and rollbacks.
  • Offline Registry Cache: Utilizes the built-in registry cache of k3s to support offline deployments, reducing dependencies on external registries.

Prerequisites

OS Packages

Install the following OS packages on your machine: (These are installed with make init)

  • build-essential: Install with sudo apt-get install build-essential
  • dnsmasq: Install with sudo apt-get install dnsmasq
  • avahi-daemon: Install with sudo apt-get install avahi-daemon
  • jq: Install with sudo apt-get install jq
  • nfs-common: Install with sudo apt-get install nfs-common
  • sshpass: Install with sudo apt-get install sshpass
  • postgresql-client: Install with sudo apt-get install postgresql-client
  • make: Install with sudo apt-get install make

External Tools/Dependencies

Install the following external tools: (These are installed with make init)

Getting Started

Build

Building the Appliance

The Crucible appliance is tested on vSphere 8, ensuring seamless compatibility and optimal performance. To start with Crucible, follow these steps:

  1. Copy the Variable File:

      `cp appliance.yaml.example appliance.yaml`
  2. Customize Your Environment:

Modify the appliance.yaml file to match your environment. This includes setting the vSphere server, user credentials, datacenter, cluster, datastore, and network details. Ensure these settings match your vSphere configuration to avoid deployment errors.

  vars:
     vsphere_server: vcsa.example.com
     vsphere_user: [email protected]
     vsphere_password: pasword1234!@
     datacenter: Datacenter1
     cluster: Cluster1
     datastore: ds1
     network_name: "VM Network"
     ssh_username: crucible
     ssh_password: crucible
  1. Initiate the Build:
   make build
  1. Import into vSphere:

    Upon successful completion of the Packer build process, an OVF directory will be located in the ./dist/output folder. Import this OVF into your vSphere environment.

Makefile Documentation

Target Dependencies Description
generate_certs Generates root CA and K3s CA certificates, distributes certs.
sudo-deps generate_certs Expands volume, installs sudo dependencies, configures netplan.
init sudo-deps Installs user dependencies, initializes Argo. This script provisions a base 22.04 ubuntu image
deps Installs sudo dependencies.
argo Initializes Argo.
gitea Sets up Gitea.
build Cleans output directories, updates variables, builds appliance.
offline-reset Performs an offline reset.
reset Resets Argo.
clean Removes build artifacts and cache.
clean-certs Removes root and intermediate SSL certificates. So new ones can be generated
snapshot Takes a manual etcd snapshot (prefix: crucible-appliance).
keycloak-realm-export Exports the Keycloak realm.

Usage

Once deployed, access the Start page at https://crucible.local

Contributing

Contributions are welcome! Please see the DEVELOPMENT.md README for detailed instructions

License

This project is licensed under the MIT License - see the LICENSE file for details.

Install the OVFTool from VMware

The OVF tool is now hosted behind a login, you'll need to install the OVFTool if you want to convert from OVF format to OVA.

  1. Download and install the OVFTool from VMware ovftool.
  2. Install it based on the instructions.

About

Crucible virtual appliance in OVF format.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •