❗ Red Hat does not provide commercial support for the content of this repo. Any assistance is purely on a best-effort basis, as resource permits.
#############################################################################
DISCLAIMER: THE CONTENT OF THIS REPO IS EXPERIMENTAL AND PROVIDED **"AS-IS"**
THE CONTENT IS PROVIDED AS REFERENCE WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
#############################################################################
This repository contains playbooks for automating the creation of an OpenShift Container Platform cluster on premise using the Developer Preview version of the OpenShift Assisted Installer. The playbooks require only minimal infrastructure configuration and do not require any pre-existing cluster. Virtual and Bare Metal deployments have been tested in restricted network environments where nodes do not have direct access to the Internet.
These playbooks assume a prior working knowledge of Ansible. They are intended to be run from a bastion
host, running a subscribed installation of RHEL 8.4, inside the target environment. Pre-requisites can be installed manually or automatically, as appropriate.
See how the playbooks are intended to be run and understand what steps the playbooks take.
Crucible targets versions of Python and Ansible that ship with RHEL. At the moment the supported versions are:
- RHEL 8.3
- Python 3.6.8
- Ansible 2.9.27
- 4.6
- 4.7
- 4.8
- v2.1.0
- v2.1.1
- v2.1.2
Requires the following to be installed on the deployment host:
- Ansible
- netaddr
- jmespath
- skopeo
- podman
- kubectl + oc
- pyghmi #For PXE deployment
- ipmitool #For PXE deployment
Important Note The openshift-clients
package is part of the Red Hat OpenShift Container Platform Subscription. The repo must be activated on the bastion host before the dependency installation. It is used for the post-installation cluster validation steps.
dnf install ansible python3-netaddr skopeo podman openshift-clients ipmitool python3-pyghmi python3-jmespath
There's also some required Ansible modules that can be installed with the following command:
ansible-galaxy collection install -r requirements.yml
- Configure NTP time sync on the BMCs and confirm the system clock among the master nodes is synchronized within a second. The installation fails when system time does not match among nodes because etcd database will not be able to converge.
- Modify the provided inventory file
inventory.yml.sample
. Fill in the appropriate values that suit your environment and deployment requirements. See the sample file and docs/inventory.md for more details. - Modify the provided inventory vault file
inventory.vault.yml.sample
. Fill in the corresponding secret values according to the configuration of the inventory file. See the sample file and docs/inventory.md#required-secrets for more details. - Place the following prerequisites in this directory:
- OpenShift pull secret stored as
pull-secret.txt
(can be downloaded from here) - SSH Public Key stored as
ssh_public_key.pub
- If
deploy_prerequisites.yml
is NOT being used; SSL self-signed certificate stored asmirror_certificate.txt
- OpenShift pull secret stored as
The inventory vault files should be encrypted and protected at all times, as they may contain secret values and sensitive information.
To encrypt a vault file named inventory.vault.yml
, issue the following command.
ansible-vault encrypt inventory.vault.yml
An encrypted vault file can be referenced when executing the playbooks with the ansible-playbook
command.
To that end, provide the option -e "@{PATH_TO_THE_VAULT_FILE}"
.
To allow Ansible to read values from an encrypted vault file, a password for decrypting the vault must be provided. Provide the --ask-vault-pass
flag to force Ansible to ask for a password to the vault before the selected playbook is executed.
A complete command to execute a playbook that takes advantage of both options can look like this:
ansible-playbook -i inventory.yml ${SELECTED_PLAYBOOK} -e "@inventory.vault.yml" --ask-vault-pass
If a need arises to decrypt an encrypted vault file, issue the following command.
ansible-vault decrypt inventory.vault.yml
For more information on working with vault files, see the Ansible Vault documentation.
Some utility playbooks are provided to perform some validation before attempting a deployment:
ansible-playbook -i inventory.yml prereq_facts_check.yml -e "@inventory.vault.yml" --ask-vault-pass
ansible-playbook -i inventory.yml playbooks/validate_inventory.yml -e "@inventory.vault.yml" --ask-vault-pass
There are a few main playbooks provided in this repository:
deploy_prerequisites.yml
: sets up the services required by Assisted Installer, and an Assisted Installer configured to use them.deploy_cluster.yml
: uses Assisted Installed to deploy a clusterpost_install.yml
: fetches thekubeconfig
for the deployed cluster and places it on the bastion host.site.yml
simply runs all three in order.
Each of the playbooks requires an inventory and an inventory vault file, and can be run like this:
ansible-playbook -i inventory.yml site.yml -e "@inventory.vault.yml" --ask-vault-pass
When performing a full deployment, Crucible may first present you with a deployment plan containing all the key configuration details. Please review the deployment plan carefully to ensure that the right inventory file has been provided. To confirm the plan and proceed with the deployment, type yes
when prompted.
In order to skip interactive prompts in environments where user input cannot be given, extend the command with the -e skip_interactive_prompts=true
option.
If this option is enabled, the generation of a deployment plan is omitted, and the deployment process starts immediately after the command is run.
# Careful: this command will start the deployment right away, and will not ask for manual confirmation.
ansible-playbook -i inventory.yml site.yml -e "@inventory.vault.yml" --ask-vault-pass \
-e skip_interactive_prompts=true
For simplicity we suggest that passwordless sudo is set up on all machines. If this is not desirable or possible in your environment then there are two options:
- Use the same sudo password for all hosts, and use the
-K
flag onansible-playbook
. This will cause Ansible to prompt for the sudo password. The password provided is then used for all hosts. - Set the
ansible_become_password
variable for each host that needs a sudo password. The passwords can be securely stored in an encrypted Ansible vault.
Crucible can automatically set up the services required to deploy and run a cluster. Some are required for the Assisted Installer tool to run, and some are needed for the resulting cluster.
- NTP - The NTP service helps to ensure clocks are synchronised across the resulting cluster which is a requirement for the cluster to function.
- Container Registry Local Mirror - Provides a local container registry within the target environment. The Crucible playbooks automatically populates the registry with required images for cluster installation. The registry will continue to be used by the resulting cluster.
- HTTP Store - Used to serve the Assisted Installer discovery ISO and allow it to be used as Virtual Media for nodes to boot from.
- DNS - Optionally set up DNS records for the required cluster endpoints, and nodes. If not automatically set up then the existing configuration will be validated.
- Assisted Installer - A pod running the Assisted Installer service, database store and UI. It will be configured for the target environment and is used by the cluster deployment playbook to coordinate the cluster deployment.
- TFTP Host - A server that stores all the file mounted from the discovery image (required only for PXE deployments).
While setup of each of these can be disabled if you wish to manually configure them, but it's highly recommended to use the automatic setup of all prerequisites.
Note that the exact changes made depend on which playbooks or roles are run, and the specific configuration.
The obvious output from these playbooks is a clean OCP cluster with minimal extra configuration. Each node that has been added to the resulting cluster will have:
- CoreOS installed and configured
- The configured SSH public key as an authorised key for
root
to allow debugging
Various setup is done on the prerequisite services. These are informational and are not needed unless you encounter issues with deployment. The following are defaults for a full setup:
-
Registry Host
opt/registry
contains the files for the registry, including the certificates.tmp/wip
is used during the playbook execution as a temporary file store.
-
DNS Host
- Using dnsmasq:
/etc/dnsmasq.d/dnsmasq.<clustername>.conf
- using Network Manager:
/etc/NetworkManager/dnsmasq.d/dnsmasq.<clustername>.conf
and/etc/NetworkManager/conf.d/dnsmasq.conf
- Using dnsmasq:
-
Assisted Installer
- A running pod containing the Assisted Installer service.
/opt/assisted-installer
contains all the files used by the Assisted Installer container
-
HTTP Store
- A running pod containing the
httpd
service - The discovery image from Assisted Installer will be placed in and served from
/opt/http_store/data
- A running pod containing the
-
TFTP Host
- The discovery image will be mounted to this server and do the PXE boot with TFTP
As well as deploying prerequisites and a cluster, the playbooks create or update various local artifacts in the repository root and the fetched/
directory (configured with fetched_dest
var in the inventory).
- An updated
pull-secret.txt
containing an additional secret to authenticate with the deployed registry. - The self-signed certificate created for the registry host as
registry.crt
. - The SSH public and private keys generated for access to the nodes, if any, at
/home/redhat/ssh_keys
(temporarily stored in/tmp/ssh_key_pair
) - Any created CoreOS ignition files.
When doing multiple runs ensure you retain any authentication artefacts you need between deploys.
Existing tests can be run from tests
directory using
ansible-playbook run_tests.yml
- How the playbooks are intended to be run
- How to configure the inventory file
- Steps the playbooks take when executed
Some useful help for troubleshooting if you find any issues can be found in docs/troubleshooting
This software was adapted from sonofspike/cluster_mgnt_roles