Avi Controller Sizing


This guide explains the system capacity of the Avi Controller.

Specifying System Capacity of Avi Controller

During deployment of an Avi Controller, the system capacity of the Avi Controller can be specified based on allocations of the following system resources:

  • CPUs
  • Memory (RAM)
  • Disk

The amount of these resources allocated to an Avi Controller have a direct impact on its performance.

The following table lists recommended allocations for each type of deployment:

Deployment Type Node Count Recommended Allocations
CPU Memory Disk
Demo/ Customer Eval 1 8 24 GB 128 GB
Production 3 See the following:
CPU/Memory Allocation
Drive Allocation

In demonstration and deployments, a single Avi Controller is adequate and is used for all control-plane activities and workflows, as well as analytics.

In a production deployment, a 3-node cluster is recommended. In a 3-node Avi Controller cluster, 1 Avi Controller is the leader Avi and is used for control-plane activities and workflows. The other 2 Avi Controllers are followers. The follower Avi Controller nodes are used for analytics. The follower Avi Controller nodes also provide backup in case the leader Avi Controller fails.

The following sections provide specific allocation recommendations. The recommendations are designed to fit most use cases, but might not fit every conceivable deployment scenario.

Allocating CPU/Memory

Avi Vantage uses the allocations of CPU and memory as follows:

CPU/Memory Allocation Essentials (4 CPUs / 12 GB) Small (8 CPUs / 24 GB) Medium (16 CPUs / 32 GB) Large (24 CPUs / 48 GB)
Base processes 11 GB 15 GB 20 GB 24 GB
Log analytics 1 GB 9 GB 13 GB 24 GB
Virtual Service Scale 0-50 0-200 200-1000 1000-5000
Avi Service Engine (SE) Scale 0-10 0-100 100-200 200-400

The Avi Controller’s base processes include dynamic processes and metrics collection and processing. The allocations shown here are based on assumptions of no more than 10 percent disk swapping and 25 percent disk margin.


  • The Essentials Controller size is supported starting with Avi Vantage release 20.1.5. But, it can only be used for a Controller deployed in the ESSENTIALS license tier in conjunction with VMware Tanzu solutions and running on-premises in a VMware environment. For more information, click System Limits.
  • There is no capability for vCenter’s hot-add feature to expand the Controller virtual machine’s CPU/ memory.

Allocating Disk Capacity

The amount of diskcapacity to allocate to an Avi Controller is calculated based on the following parameters:

  • the amount of disk capacity available on the Avi Controller
  • the number of virtual services to support.

Note the following:

  • Starting with Avi Vantage version 18.2.6, the default Controller OVA template should be increased to 128 GB.

  • Controllers in the same cluster should all have the same/similar disk capacity. Allocations of significantly different sizes should not be permitted for prolonged periods of time.

The following tables show recommended allocations based on each approach.

Allocating Disk based on available Disk Capacity

The disk space allocated to an Avi Controller that is not used for base processes or analytics is used as follows:

  • Logs: 70 percent of the disk that is not used for base processes or analytics.
  • Metrics: the other 30 percent that is not used for base processes or analytics.
Disk Allocation based on Disk Space 128 GB 256 GB 512 GB 1 TB
Log analytics (70%) 56 GB 144 GB 328 GB 672 GB
Metrics (30%) 24 GB 64 GB 128 GB 288 GB
Base Processes 48 GB 48 GB 56 GB 64 GB

Disk drive quality impacts analytics performance and size:

  • Traffic logs are deleted as the disk drive fills up.
  • Metrics tables are deleted based on the archival scheme:
    • Realtime: deleted after 1 hour
    • 5-minute intervals: deleted after 1 day
    • 1-hour intervals: deleted after 1 week
    • 1-day intervals: deleted after 1 year

If the drive fills up, then current metrics tables are deleted to make room for new data.

Allocating Disk based on Number of Virtual Services

Disk allocation based on VS count Log analytics without full logs Log analytics with full logs Metrics Base processes Total (without full logs)
100 VS 16 GB 128 GB 16 GB 48 GB 80 GB
1,000 VS
(100k transactions / year)
128 GB 1 TB 32 GB 56 GB 216 GB
5,000 VS 512 GB Not sptd 160 GB 64 GB 736 GB

Assumptions and Sizing Data

The size recommendations shown in the table are based on the following operational assumptions:

  • DDoS attacks are less than 1 percent of the traffic.
  • Significant logs are no more than 10 percent of total logs. (This means 90 percent of the transactions are good and result only in non-significant logs.)
  • Log analytics require about 10 kB disk space per log entry, i.e., 10 GB of disk space for 1 million log entries.
  • Metrics and other analytics processing requires about 32 MB per virtual service. Client insights require additional drive capacity.

Note: A transaction is a single TCP or UDP connection (layer 4), or a single request-response exchange (layer 7). Traffic volume of 100,000 transactions per year is probably low for an e-commerce site but is applicable to most other types of applications.

Checking the Controller Flavour on Avi Vantage

Use the api/cluster/status API command to check the Controller flavor that is in use on the selected Avi Vantage.
"node_info": {
"uuid": "00505681b9f4",
"ip": "node1.controller.local",
"mgmt_ip": "",
"version": "20.1.5(9000) 2021-03-31 16:17:01 UTC",
"vm_uuid": "00505681b9f4",
"vm_mor": "vm-83383",
"cluster_uuid": "cluster-aec31f94-d2f6-466f-9fc5-c0c180e5c949",
"fips_operational": "False"
"node_states": [
"state": "CLUSTER_ACTIVE",
"name": "",
"mgmt_ip": "",
"up_since": "2021-04-01 17:52:25"
"cluster_state": {
"up_since": "2021-04-01 17:52:25",
"state": "CLUSTER_UP_NO_HA",
"progress": 100

Use the show cluster flavor CLI command to check the Controller flavor that is in use on the selected Avi Vantage.

[admin:10-10.10.1]: > show cluster flavor
| Flavor                |

Additional Information

FAQ on Avi Controller cluster.