Cloudify Cluster Manager
Cluster Manager
The purpose of the Cluster Manager package is to automate the procedure of installing a Cloudify cluster on existing VMs. The following article will guide you through the different steps of easily installing a Cloudify cluster on either three or nine VMs.
Installation
Choosing a cluster configuration
Before using the Cluster Manager package you must prepare a set of VMs for your cluster. The Cluster Manager package supports all cloud providers and the following configurations:
- Fully distributed cluster (9 VMs).
- Compact cluster (3 VMs).
- Fully distributed cluster with an external DB (6 VMs).
- Compact cluster with an external DB (3 VMs).
Please follow the prerequisites and sizing guidelines and generate the required number of VMs according to the mentioned spec. You should also prepare a load balancer to distribute the load over the managers.
NOTE
- The Cluster Manager package is currently supported over CentOS or RHEL OS.
- A load-balancer is required for load distribution over the managers. The setup will expect a load balancer address. The Cluster Manager package does not install the load balancer.
Installing the Cluster Manager package
You can run the Cluster Manager package from one of the cluster’s VMs, or from a different host in the
cluster network. You can install the package either by using an RPM or by using pip install
:
Installing using an RPM
Run the following command:
sudo yum install -y http://repository.cloudifysource.org/cloudify/cloudify-cluster-manager/1.0.9/ga-release/cloudify-cluster-manager-1.0.9-ga.el7.x86_64.rpm
# Installing haveged to avoid hanging executions
sudo yum install -y epel-release
sudo yum install -y haveged
sudo systemctl start haveged
Installing using pip install
pip install cloudify-cluster-manager
# Installing haveged to avoid hanging executions
sudo yum install -y epel-release
sudo yum install -y haveged
sudo systemctl start haveged
Using the Cluster Manager package
Once the VMs are ready, using the Cluster Manager package to build the cluster consists of three steps:
- Generating a cluster configuration file template based on the cluster topology you wish to deploy.
- Filling in the generated file with the relevant information.
- Running the cluster installation based on the completed configuration file.
Generating a configuration file
Generating the configuration file is done using the command:
cfy_cluster_manager generate-config [OPTIONS]
Options
-o, --output-path
- The local path to save the cluster install configuration file to. Default: ./cfy_cluster_config.yaml--three-nodes
- Using a three nodes cluster.--nine-nodes
- Using a nine nodes cluster. In case of using an external DB, Only 6 nodes will need to be provided.--external-db
- Using an external DB.-v, --verbose
- Show verbose output.-h, --help
- Show this help message and exit.
NOTE: --three-nodes
or --nine-nodes
must be specified, and they cannot be specified together.
Filling in the configuration file
General Note
Fill in the information according to the comments in the file itself. NOTE! Do not delete anything from the file.
Load-balancer
As mentioned before, a load-balancer is not installed as part of the cluster installation.
The load_balancer_ip
value is used in the different config.yaml files for the instances’ connection.
Certificates
If you wish to use your own certificates:
- Fill in the
ca_cert_path
value and thecert_path
andkey_path
values for each VM (all of them). - In case that a VM’s certificate’s SAN includes the VM host-name, please specify this host-name as the value
of the
hostname
key.
- Fill in the
Otherwise: Cloudify signed certificates will be generated and used automatically.
config.yaml files
If you wish to use your own config.yaml files for the different instances, you may do so by specifying their path as the value of the
config_path
in each one of the instances (all of them).Otherwise, preconfigured config.yaml files will be generated and used automatically.
Note: If you use your own config files, you cannot specify the certificates’ paths for the different instances. Moreover, the ldap, external_db, and credentials sections in the configuration file will be ignored.
Credentials
If you wish to use your own credentials, you can specify them in the
credentials
section.Unfilled credentials will be generated and used by the Cluster Manager package. The generated credentials are random.
WARNING: At the end of the installation, a file named
secret_credentials_file.yaml
will be created in the current directory. This file includes the credentials in clear text. Please, remove it after reviewing it or store it in a safe location.
Installing a Cloudify cluster
Now that the configuration file is completed, we can move on to the cluster installation using the following command:
cfy_cluster_manager install [OPTIONS]
Options
-- config-path
- The completed cluster configuration file path. Default: ./cfy_cluster_config.yaml--override
- If specified, any previous installation of Cloudify on the instances will be removed.--validate
- Validate the provided configuration file.-v, --verbose
- Show verbose output.-h, --help
- Show this help message and exit.
Removing a Cloudify cluster
The created Cloudify cluster can be removed using the following command:
cfy_cluster_manager remove [OPTIONS]
Options
-- config-path
- The completed cluster configuration file path. Default: ./cfy_cluster_config.yaml-v, --verbose
- Show verbose output.-h, --help
- Show this help message and exit.
Upgrading a Cloudify cluster
The Cloudify cluster can be upgraded from v5.1.0 (or any later release) to a more recent version using the following command:
cfy_cluster_manager upgrade [OPTIONS]
Options
--config-path
- The completed cluster configuration file path. Default: ./cfy_cluster_config.yaml--upgrade-rpm
- Path to a cloudify-manager-install RPM. This can be either a local or remote path.-v, --verbose
- Show verbose output.-h, --help
- Show this help message and exit.
Fault tolerance mechanisms
The Cluster Manager package has a few mechanisms to handle errors:
The configuration file is validated before it is being used.
The connection to each instance is tested before the installation starts.
The
cfy_manager install
command is run usingsystemd-run
on the different instances. I.e. if the SSH connection is interrupted, the installation keeps on running because it’s configured as a child process of the init process.In case of a recoverable error during the installation, you can just run the
cfy_cluster_manager install
command again. The installation process would:- Go over the instances and check if they were installed successfully.
- Once it gets to the failed instance, it would remove the failed installation, and continue the installation from there.
In case of an unrecoverable error during the installation, you can run it again using:
cfy_manager install --override
.
This command would:- Go over the instances and remove Cloudify from them (including the RPM).
- Run the installation process from the start.