Nutanix Command Line Interface (nCLI) provides another command-line interface for executing commands in a Nutanix Cluster. This article will give some valuable examples of this critical tool.
First and foremost, How can I execute the nCLI?
To run nCLI, we can access any Controller VM (CVM) in the cluster:
data:image/s3,"s3://crabby-images/84126/84126ffd3469c94a3f6c230533c12d7b335318fc" alt=""
Since we are using the Nutanix AOS 6.5 in our lab environment, the following documentation can be used for all nCLI options:
https://portal.nutanix.com/page/documents/details?targetId=Command-Ref-AOS-v6_5:man-ncli-c.html
Executing nCLI to Get Cluster Details (ncli cluster)
Checking the configured cluster name servers (DNS servers) and NTP servers:
#Getting configured DNS servers on the Nutanix cluster:
ncli cluster get-name-servers
#Getting configured NTP servers on the Nutanix cluster:
ncli cluster get-ntp-servers
data:image/s3,"s3://crabby-images/9be02/9be02497e4156de69cc24a5f43d25dcb065b75e9" alt=""
We can use the following command to get:
- Cluster ID and UUID
- Cluster Name and Version
- Virtual IP address (aka External IP address)
- Node count
- External IP Data Services
- RF1 Container Support (Enabled or not)
- NCC version
- Etc…….
ncli cluster get-params
data:image/s3,"s3://crabby-images/3e6b6/3e6b650da397f5036f2f381f0de4ea4f495a6bbf" alt=""
If you need to get only the cluster version:
ncli cluster version
data:image/s3,"s3://crabby-images/51b4c/51b4c8985f5bfb44b8f51972be7b97bd34aafd5d" alt=""
To get the cluster redundancy state (Redundancy Factor) and resiliency preference:
#Getting the cluster redundancy state:
ncli cluster get-redundancy-state
#Getting the cluster resiliency preference:
ncli cluster get-resiliency-preference
data:image/s3,"s3://crabby-images/c46db/c46db940453a26c1d3c8a0870426bd35ef4de158" alt=""
To get the status for all cluster services (on all Controller VMs):
ncli cluster status
data:image/s3,"s3://crabby-images/f769b/f769b164b5afb29e59b7ac16528b392b0eb6469d" alt=""
(…we have omitted the total command output….)
Executing nCLI to Get Host Details (ncli host)
To list all hosts (hypervisors) and their details:
ncli host list
data:image/s3,"s3://crabby-images/f1c47/f1c477acb6b63ebd84fc000c205878bdce71766c" alt=""
To get stats data for hosts:
ncli host list-stats
data:image/s3,"s3://crabby-images/dbf9c/dbf9ce77c790a1af0bbf8465d44fc461ae2fa81a" alt=""
Example of usage: To get the current CPU and Memory usage (%) for all Hypervisors:
ncli host list-stats | egrep -i "Hypervisor|CPU Usage|Memory" | awk '/CPU Usage Percent/ {print; print "-----------------------"} !/CPU Usage Percent/ {print}'
or
ncli host list-stats | egrep -i "Hypervisor|CPU Usage|Memory" | sed '/CPU Usage Percent/a --------------------------'
data:image/s3,"s3://crabby-images/9651f/9651f96e18ecbfb925ec553540225496e6e4fef9" alt=""
Executing nCLI to Get VM Details (ncli virtualmachine)
To list all virtual machines (VMs):
ncli virtualmachine list
data:image/s3,"s3://crabby-images/c4b5e/c4b5ed236d015728593ebcbae4b1a5123191a224" alt=""
To get stats for each virtual machine (VM):
ncli virtualmachine list-stats
data:image/s3,"s3://crabby-images/bc88a/bc88a71613eb99c67b5ea4f76c850e566e72cfdd" alt=""
Example of Usage: To get the CPU usage (%) and Memory Usage (bytes) for all Controller VMs (CVMs):
ncli virtualmachine list-stats | egrep -i "Name|CPU Usage|Memory Usage" | grep -A2 '\CVM' | sed '/Memory Usage/a --'
data:image/s3,"s3://crabby-images/c3a01/c3a01991ddc07a1d6c8819dbc02a2a3b34d2f846" alt=""
That’s it 🙂