This repository contains the Rancher Node Driver for Nutanix. Nutanix Node driver are used to provision hosts on Nutanix Enterprise Cloud, which Rancher uses to launch and manage Kubernetes clusters.
- Configure Prism Central and corresponding user to talk to Nutanix platform
- Define target cluster to deploy VM
- Ability to set a custom name for the newly created VM
- Ability to select VM's Main Memory in Megabytes
- Ability to select VM's vCPU count
- Ability to set the number of cores per vCPU
- Ability to specify the network(s) of the VM (Classic or VPC)
- Ability to specify the template disk in the VM by image name and modify his size (increase only)
- Ability to specify categories to applied to the VM ( flow, leap, ...)
- Ability to add one additional disk by specifying disk-size and storage-container
- Enable passthrough the host's CPU features to the newly created VM
- Define a Cloud-init user-data to send to the newly created VM
- Project support
- Serial Port support
- Boot type selection : Legacy or UEFI
- GPU support
If you want to use Nutanix Node Driver, you need add it in order to start using them to create node templates and eventually node pools for your Kubernetes cluster.
- 
From the Home view, choose Cluster Management > Drivers in the navigation bar. From the Drivers page, select the Node Drivers tab. 
- 
Click Add Node Driver. 
- 
Complete the Add Node Driver form. Then click Create. - Download URL: https://github.com/nutanix/docker-machine/releases/download/v3.7.0/docker-machine-driver-nutanix
- Custom UI URL: https://nutanix.github.io/rancher-ui-driver/v3.7.0/component.js
- Checksum: 2f70c4bdccd3c5e68bd8c32aadb5b525275a3cda5799f29736f37bdd168caa94
- Whitelist Domains: nutanix.github.io
 whitelist is mandatory and need to be changed if you relocate the UI driver 
- Download URL: 
- Wait for the driver to become "Active"
- Go to RKE1 Configuration > Node Templates, your can create a Nutanix Template and custom UI should show up.
| Arg | Description | Required | Default | 
|---|---|---|---|
| nutanix-endpoint | The hostname/ip-address of the Prism Central | yes | |
| nutanix-port | The port to connect to Prism Central | no | 9440 | 
| nutanix-username | The username of the nutanix management account | yes | |
| nutanix-password | The password of the nutanix management account | yes | |
| nutanix-insecure | Set to true to force SSL insecure connection | no | false | 
| nutanix-cluster | The name of the cluster where deploy the VM (case sensitive) | yes | |
| nutanix-boot-type | The boot type of the VM (legacy or uefi) | no | legacy | 
| nutanix-vm-mem | The amount of RAM of the newly created VM (MB) | no | 2 GB | 
| nutanix-vm-cpus | The number of cpus in the newly created VM (core) | no | 2 | 
| nutanix-vm-cores | The number of cores per vCPU | no | 1 | 
| nutanix-vm-network | The network(s) to which the VM is attached to ( name or UUID ) | yes | |
| nutanix-vm-image | The name of the Disk Image template we use for the newly created VM (must support cloud-init) | yes | |
| nutanix-vm-image-size | The new size of the Image we use as a template (in GiB) | no | |
| nutanix-vm-categories | The name of the categories who will be applied to the newly created VM | no | |
| nutanix-vm-gpu | The name of GPU to attach to the newly created VM | no | |
| nutanix-project | The name of the project where deploy the VM (default if empty) | no | default | 
| nutanix-disk-size | The size of the additional disk to add to the VM (in GiB) | no | |
| nutanix-storage-container | The storage container UUID of the additional disk to add to the VM | no | |
| nutanix-cloud-init | Cloud-init to provide to the VM (will be patched with rancher root user) | no | |
| nutanix-vm-cpu-passthrough | Enable passthrough the host's CPU features to the newly created VM | no | false | 
| nutanix-vm-serial-port | Attach a serial port to the newly created VM | no | false | 
Starting v3.3.0 the Rancher Node driver implements Nutanix Project support. The  prerequisite needed to be able to use the Rancher Node Driver is the following:
- Target cluster and network available in the Project
- Role with the following recommended permission:
- VM Full Access
- Cluster View Access
- Image View Only
 
build linux/amd64 binary => make
build local binary => make local
- v1 is the original Nutanix docker machine driver that connect to Prism Element
- v2.x add Rancher 2.0 support
- v3.x is a rewrite of the driver that connect to Prism Central
This code is developed in the open with input from the community through issues and PRs. A Nutanix engineering team serves as the maintainer. Documentation is available in the project repository. Issues and enhancement requests can be submitted in the Issues tab of this repository. Please search for and review the existing open issues before submitting a new issue.
Copyright 2022-2023 Nutanix, Inc.
The project is released under Mozilla Public License Version 2.0.