-
Notifications
You must be signed in to change notification settings - Fork 45
HA provisioning on 3 node VM cluster: Manual
-
Make sure that all cortx components except cortx-ha have been installed and configured on all of the 3-nodes.
-
Install cortx-py-utils if not installed already.
-
Install and setup Corosync/Pacamaker on all of the 3-nodes:
3.1 Make sure /etc/hosts is reflected properly or DNS is updated to resolve host names.
E.g. $ cat /etc/hosts 10.230.241.214 srvnode-1
3.2 Install EPEL Repository, corosync, pacemaker and pcsd.
$ yum -y install epel-release $ yum -y install corosync pacemaker pcs
3.3 Enable pacemaker, corosync, and pcsd service
$ systemctl enable pcsd $ systemctl enable corosync $ systemctl enable pacemaker
3.4 Start pcsd service
$ systemctl start pcsd
3.5 Configure a password for the 'hacluster' user. Here for given wiki "admin" is used as password.
$ echo <new-password> | passwd --stdin hacluster
- Add repository for Cortx
$ yum-config-manager --add-repo <Link to the cortx_iso>
- Install cortx-ha
$ yum -y install cortx-ha
Open python3 prompt on one of the 3-nodes and run following commands:
$ from cortx.utils.security.cipher import Cipher, CipherInvalidToken
$ key = Cipher.generate_key(cluster_id, 'corosync-pacemaker')
Here use the same cluster_id as it will be added to confstore files.
$ encrypt_text = Cipher.encrypt(key, 'admin'.encode('ascii'))
Here 'admin' is the password that we want to use (from step 3.5 above).
$ print(encrypt_text)
b'gAAAAABgCSb6rPYYM_59JNS8hLAnQt-J1FniehFJ-XW6QGE2T38rSVXoE1VnUkSE5R2qh8NuAtvxs5SCQ8khTa2LmUnF2fBhYA=='
Update following confstore template files on all of the 3-nodes.
```
1. /opt/seagate/cortx/ha/conf/ha.post-install.tmpl.3-node
2. /opt/seagate/cortx/ha/conf/ha.prepare.tmpl.3-node
```
These files do not contain any keys as of now, hence no need to update these.
```
3. /opt/seagate/cortx/ha/conf/ha.config.tmpl.3-node
```
a. Replace TMPL_MACHINE_ID with machine-id of particular VM. Run following command to get machine-id of the VM:
```
$ cat /etc/machine-id
```
b. Replace TMPL_CLUSTER_ID with the cluster-id to be used. Use the same value across 3-nodes.
c. Replace TMPL_NAME with the cluster name to be used. Use the same value across 3-nodes.
d. Replace TMPL_PRIVATE_FQDN with the hostname used in the step #3.1 above for a particular node.
e. Replace TMPL_TYPE with "VM".
f. Replace TMPL_USER with the HA cluster user used in step #3.5 i.e. "hacluster".
g. Replace TMPL_SECRET with the encrypted pacemaker cluster user password.
```
4. /opt/seagate/cortx/ha/conf/ha.init.tmpl.3-node
5. /opt/seagate/cortx/ha/conf/ha.test.tmpl.3-node
6. /opt/seagate/cortx/ha/conf/ha.reset.tmpl.3-node
7. /opt/seagate/cortx/ha/conf/ha.cleanup.tmpl.3-node
```
Make changes same as the ha.config.tmpl.3-node file above.
Run following mini-provisioning commands on the 3-nodes as per the Cortx 3-node deployment workflow.
$ ha_setup post_install --config "yaml:///opt/seagate/cortx/ha/conf/ha.post-install.tmpl.3-node"
$ ha_setup prepare --config "yaml:///opt/seagate/cortx/ha/conf/ha.prepare.tmpl.3-node"
$ ha_setup config --config "yaml:///opt/seagate/cortx/ha/conf/ha.config.tmpl.3-node"
With above commands the cortx-ha should be provisioned. Following commands are empty currently and provided just for the completeness.
$ ha_setup init --config "yaml:///opt/seagate/cortx/ha/conf/ha.init.tmpl.3-node"
$ ha_setup test --config "yaml:///opt/seagate/cortx/ha/conf/ha.test.tmpl.3-node"
$ ha_setup reset --config "yaml:///opt/seagate/cortx/ha/conf/ha.reset.tmpl.3-node"
If need to revert the cortx-ha configuration then run:
$ ha_setup cleanup --config "yaml:///opt/seagate/cortx/ha/conf/ha.cleanup.tmpl.3-node"
$ cortx cluster start