Prerequisites and Sizing Guidelines for Installing a Cloudify Manager

Before you install the Cloudify Manager, please review the following prerequisites and make sure that your environment is ready to support the Cloudify Manager.

Cloudify All-in-One

All-in-One (AIO) deployment is based on a single Cloudify box (single VM/Container) running all the Cloudify components, mainly the manager, the database and the messaging queue. An AIO deployment is recommended for non-mission critical use when High-availability is not required and the scale is not extreme. Cloudify AIO is typically used for development and testing systems, but also common in production for smaller-scale areas.

Recommended Resources

- Minimum Recommended
vCPUs 2 8
RAM 4GB 16GB
Storage 20GB 64GB

Cloudify Compact cluster (3 nodes)

The Cloudify Compact cluster deployment is based on 3 servers, each running all of the Cloudify services, where the services are deployed in an active-active approach with a high-availability setup. A Compact cluster provides an enterprise grade Cloudify deployment suitable to almost any organization, with a performance and scale equivelent to a fully distributed cluster containing 3 managers and with the option offurther scaling using higher form factor hardware. The compact cluster is designed for mission critical use.

Recommended Resources for each of the 3 nodes:

- Recommended
vCPUs 8
RAM 16GB
Storage 64GB

Cloudify fully distributed cluster

A Cloudify cluster consists of 3 main services: Cloudify Manager, Database, and Messaging queue. Cloudify cluster topology assures high availability and should be leveraged for mission-critical deployments. Learn more about the Cloudify cluster

Cloudify Manager server

For a highly available setup at lease two managers are required, 3 are recommended.

Recommended resources per manager server

- Recommended
vCPUs 4
RAM 8GB
Storage 32GB

Database (PostgreSQL) server

For a highly available setup, 3 database servers are required.

Recommended resources per database server

- Recommended
vCPUs 2
RAM 16GB
Storage 64GB

Messaging queue (RabbitMQ) server

For a highly available setup, 3 messaging queue servers are required.

Recommended resources per messaging queue server

- Recommended
vCPUs 2
RAM 4GB
Storage 32GB

Sizing Guidelines

Defining the exact sizing of a Cloudify Manager is tricky because there are many variants in the equation. That said, here are some guidelines and insights to how such sizing can be determined.

Tenants

Up to 1000 tenants may be defined in a Cloudify Manager/cluster.

Users

There is virtually no limit to the number of users defined in the system. The max number of concurrent users interacting with the manager is 200 (based on the recommended spec above.

Blueprints

There is no limit on the number of blueprints other than their size. Blueprints are stored in on the manager hard drive and in the database and are relatively small entities. A very large blueprint may consume 1M of disk space and similar size in the DB. most will require much less than that. Cloudify recommends allocating 50GB of storage to the manager which should suffice for most customers.

Plugins

There is no limit on the number of plugins other than their size. Plugins are stored in the manager hard drive. A typical plugin consumes approximately 5M. Very large plugins consume 20M of storage.

Deployments

A single Cloudify Manager/manager cluster can maintain up to 500K deployed nodes. Deployments are very light and consume very little space in the DB/hard drive. A typical deployment size would be up to 10K of disk size and consume very few entries in the DB.

Workflows

A Cloudify Manager/cluster can operate up to 100 concurrent workflows. This threshold is enforced by the system. Note: This threshold may be modified in the configuration, however, Cloudify recommends keeping the default.

Secrets

There is virtually no limit to the number of secrets.

Agents

Up to 2000 agents may be deployed per single Cloudify Manager/manager cluster.

UI/CLI/API requests per second

The REST API performance varies depending on multiple factors, but as a guideline, you should expect the Cloudify Manager to support up to 10 requests per second with the above-recommended spec.

Events

The system can run and track up to 100 events per second with the above-recommended spec.

Logs, events and metrics

You must have enough storage to store the logs, events and metrics sent from the hosts. You can configure log rotation to reduce the amount of storage space required.

Architecture and OS

Cloudify Manager is supported for installation on a 64-bit host with RHEL/CentOS 7.6.

Cloudify Images for OpenStack and Docker

You can also create a Cloudify Manager with the OpenStack or Docker images available at downloads.

Network

Network Interfaces

The Cloudify Manager requires at least 2 network interfaces with configured IP addresses:

Connectivity requirements These are the minimal requirements for production systems. * Internal communication - between Cloudify management cluster entities - at least 1Gbps connection with a latency of 1msec or less. * Cloudify Agent to manager communication - at least 100Mbps connection with a latency of 50ms or less.

Network Ports The Cloudify Manager listens on the following ports:

Port Description
80 REST API and UI. This port must be accessible when SSL is not enabled.
443 REST API and UI. This port must be accessible when SSL is enabled.
22 For remote access to the manager from the Cloudify CLI. (Optional)
5671 RabbitMQ. This port must be accessible from agent VMs.
8009 Monitoring service port.
53333 Internal REST communications. This port must be accessible from agent VMs.

Additionally, when Cloudify is deployed in a cluster topology, the following ports should be allowed:

Database nodes access to each other:

Port Description
2379 Etcd client-server for patroni cluster state.
2380 Etcd server-server for patroni cluster state.
5432 PostgreSQL replication.
8008 Patroni api for retrieving cluster state.

Manager access to database servers:

Port Description
5432 Database access.
8008 Patroni, for determining DB node state.
8009 Monitoring service port.

Messaging queue (RabbitMQ) nodes access to each other:

Port Description
4369 epmd for discovery operations.
25671 Server-server rabbit communication.

Manager access to messaging queue servers:

Port Description
4369 epmd for discovery operations.
5671 Brokers access.
15671 Accessing the management plugin for user management.
8009 Monitoring service port.

Manager to manager access:

Port Description
22000 Syncthing for file replication.
8009 Monitoring service port.

All ports are TCP unless noted otherwise.

Reverse DNS lookup

Reverse DNS lookup must be available for the RabbitMQ nodes.

Prerequisite Packages

Software requirements

These are specific packages that are commonly included in RHEL/CentOS. You must have these packages installed before you install the Cloudify Manager:

Package Description Cloudify Manager PostgreSQL Database RabbitMQ Server
sudo Passwordless sudo is required to run commands with root privileges (note that this is still a requirement even when running with root user) V V
systemd Create Cloudify Services V V V
yum Install Cloudify’s required packages V V V
openssl-1.0.2k Generate internal/external certificates V
openssh-server Creating SSH keys during the sanity check V
logrotate Rotating Cloudify log files V V V
initscripts Required by RabbitMQ V
sed Required by the CLI V
tar Untar packages V
python-setuptools Required by Python V V V
python-backports Required by Python V V V
python-backports-ssl_match_hostname Required by Python V V V
policycoreutils-python Required if SELinux is enforcing V V V

Interoperability

The Cloudify Manager is a complete application. As such, it contains several installed dependencies such as PostgreSQL, NGINX, RabbitMQ, and others. It is required that you install Cloudify Manager on a standalone VM or container and do not co-locate any other applications on that machine or container (beyond possible monitoring or logging software). You must install the Cloudify Manager as described in the installation instructions in this guide.