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.

Manager Resources

Resources requirements for installing Cloudify Manager or one of its components:

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

The minimum requirements are enough for a manager running just a few compute instances, typically for developer use, POC, or a small edge site. Managers running large deployments require at least the recommended resources.

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 250K 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.4.

Cloudify Images for Amazon, OpenStack, and Docker

You can also create a Cloudify Manager with the Amazon AWS, OpenStack, or Docker images available at Cloudify 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.
53333 Internal REST communications. This port must be accessible from agent VMs.

Additionally, when the Manager is part of a Cloudify Manager cluster, the following ports must be accessible from all the other nodes in the cluster:

Port Description
8300 Internal port for the distributed key/value store.
8301 Internal port for TCP and UDP heartbeats. Must be accessible for both TCP and UDP.
8500 Port used for outage recovery in the event that half of the nodes in the cluster failed.
15432 Database replication port.
22000 Filesystem replication 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 Required to run commands with root privileges (note that this is still a requirement even when running with root user) V V
systemd-sysv 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

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.