# Adding RHEL 8.6 worker nodes to RHOCP cluster using Ansible playbooks

The Lite Touch Installation (LTI) package includes Ansible playbooks with scripts to add the RHEL 8.6 worker nodes to the RHOCP cluster. You can use one of the following two methods to add the RHEL 8.6 worker nodes:

  • Run a consolidated playbook: This method includes a single playbook, site.yml, that contains a script to perform all the tasks for adding the RHEL 8.6 worker nodes to the existing RHOCP cluster. To run LTI using a consolidated playbook:
$ ansible-playbook -i inventory/hosts site.yaml
  • Run individual playbooks: This method includes multiple playbooks with scripts that enable you to deploy specific tasks for adding the RHEL 8.6 worker nodes to the existing RHOCP cluster. The playbooks in this method must be executed in a specific sequence to add the worker nodes. The following table includes the purpose of each playbook required for the deployment:

TABLE 9. Add RHEL 8.6 nodes using Ansible playbooks

Playbook Description
rhel8_os_deployment.yml This playbook contains the scripts to deploy RHEL 8.6 OS on worker nodes.
copy_ssh.yml This playbook contains the script to copy the SSH public key to the RHEL 8.6 worker nodes.
prepare_worker_nodes.yml This playbook contains the script to prepare nodes for the RHEL 8.6 worker nodes.
ntp.yml This playbook contains the script to create NTP setup to enable time synchronization on the worker nodes.
openshift-ansible/playbooks/scaleup.yml This playbook contains the script to add worker nodes to the RHOCP cluster. This playbook queries the master, generates and distributes new certificates for the new hosts, and then runs the configuration playbooks on the new hosts.

To run individual playbooks:

Do one of the following:

  1. Edit site.yaml file and add a comment for all the playbooks except the ones that you want to execute.

For example, add the following comments in the site.yaml file to deploy RHEL 8.6 OS on the worker nodes:

import_playbook: playbooks/rhel8_os_deployment.yml

# import_playbook: playbooks/copy_ssh.yml

# import_playbook: playbooks/prepare_worker_nodes.yml

# import_playbook: playbooks/ntp.yml

# import_playbook: openshift-ansible/playbooks/scaleup.yml

OR

Run the individual YAML files using the following command:

$ ansible-playbook -i hosts playbooks/<yaml_filename>.yml

For example, run the following YAML file to deploy RHEL 8.6 OS on the worker nodes:

$ ansible-playbook -i hosts playbooks/rhel8_os_deployment.yml

For more information on executing individual playbooks, see the consecutive sections.

# Adding RHEL 8.6 worker nodes

This section describes how to add RHEL 8.6 worker nodes to an existing RHOCP cluster.

To add RHEL 8.6 worker nodes to the RHOCP cluster:

  1. Login to the Installer VM.

This installer VM was created as a KVM VM on one of the head nodes using the rhel7_installerVM.yml playbook. For more information, see the Creating RHEL 7 installer machine section.

  1. Navigate to the /opt/NGS-OpenShift/worker_nodes/ directory, edit the input.yaml and inventory/hosts files, and enter the values as per your setup.
  2. Copy RHEL 8.6 DVD ISO to the /usr/share/nginx/html/ directory.
  3. Navigate to the /opt/ hpe-solutions-openshift/DL-LTI-Openshift/worker_nodes directory and run the following command:
$ sh setup.sh
  1. Add the worker nodes to the cluster using one of the following methods:
  • Run the following sequence of playbooks: ansible-playbook -i hosts playbooks/rhel8_os_deployment.yml
ansible-playbook -i hosts playbooks/copy_ssh.yml

ansible-playbook -i hosts playbooks/prepare_worker_nodes.yml

ansible-playbook -i hosts playbooks/ntp.yml

ansible-playbook -i hosts playbooks/scaleup.yml
  • OR
  • If you want to deploy the entire solution to add the worker nodes to the cluster, execute the following playbook:
$ ansible-playbook -i inventory/hosts site.yaml
  1. Once all the playbooks are executed successfully, check the status of the node using the following command:
$ oc get nodes

The following output is displayed:

NAME			STATUS	ROLES		AGE	VERSION

master0.ocp.ngs.local	Ready	master,worker	13d	v1.23.3+e419edf

master1.ocp.ngs.local	Ready	master,worker	13d	v1.23.3+e419edf

master2.ocp.ngs.local	Ready	master,worker	13d	v1.23.3+e419edf

worker1.ocp.ngs.local	Ready	worker		23h	v1.23.5+3afdacb

worker2.ocp.ngs.local	Ready	worker		23h	v1.23.5+3afdacb

worker3.ocp.ngs.local	Ready	worker		23h	v1.23.5+3afdacb
  1. Once the worker nodes are added to the cluster, set the “mastersSchedulable” parameter as false to ensure that the master nodes are not used to schedule pods.
  2. Edit the schedulers.config.openshift.io resource.
$ oc edit schedulers.config.openshift.io cluster
  1. Configure the mastersSchedulable field.
apiVersion: config.openshift.io/v1 

kind: Scheduler 

metadata: 

`	`creationTimestamp: “2019-09-10T03:04:05Z"

`	`generation: 1

`	`name: cluster

`	`resourceVersion: “433"

`	`selfLink: /apis/config.openshift.io/v1/schedulers/cluster

`	`uid: a636d30a-d377-11e9-88d4-0a60097bee62

spec:

`	`mastersSchedulable: false 

`	`policy:

`		`name: “"

status: { }

NOTE

Set the mastersSchedulable to true to allow Control Plane nodes to be schedulable or false to disallow Control Plane nodes to be schedulable.

  1. Save the file to apply the changes.
$ oc get nodes

The following output is displayed:

NAME			STATUS	ROLES	AGE	VERSION

master0.ocp.ngs.local	Ready	master	13d	v1.23.3+e419edf

master1.ocp.ngs.local	Ready	master	13d	v1.23.3+e419edf

master2.ocp.ngs.local	Ready	master	13d	v1.23.3+e419edf

worker1.ocp.ngs.local	Ready	worker	23h	v1.23.5+3afdacb

worker2.ocp.ngs.local	Ready	worker	23h	v1.23.5+3afdacb

worker3.ocp.ngs.local	Ready	worker	23h	v1.23.5+3afdacb

NOTE

To add more worker nodes, update worker details in HAProxy and binddns on head nodes and then add RHEL 8.6 worker nodes to the RHOCP cluster.