FlexPod Converged Infrastructure setup using Ansible for FlexPod Datacenter with Cisco UCS IMM, VMware vSphere 7.0, and NetApp ONTAP 9.13.1 and 9.14.1 with ONTAP security hardening best practices
Note that the scripts in this repository have now been successfully tested with NetApp ONTAP 9.13.1, NetApp ONTAP 9.14.1, and VMware vSphere 7.0 Update 3.
This repository for FlexPod contains Ansible playbooks to configure Cisco Nexus, Cisco UCS Intersight, Cisco MDS, NetApp ONTAP, VMware ESXi, and VMware vCenter. This repository can be used for setting up Cisco devices, NetApp ONTAP Storage, and VMware ESXi and vCenter as covered in the following Cisco Validated Design (CVD) FlexPod Datacenter Zero Trust Framework and NetApp Technical Report (TR) FlexPod Security Hardening.
The CVD lays out the complete process for configuring the FlexPod using Ansible. Since these playbooks are intended to save time in setting up a working FlexPod, a complete FlexPod as shown below is needed to execute the playbooks. Various simulators could be used to partially test individual playbooks.
To execute various ansible playbooks, a linux based system will need to be setup as described in the CVD with the packages listed at the following pages:
- Cisco UCS Intersight: https://galaxy.ansible.com/ui/repo/published/cisco/intersight/
- Cisco NxOS: https://galaxy.ansible.com/ui/repo/published/cisco/nxos/
- NetApp ONTAP: https://galaxy.ansible.com/ui/repo/published/netapp/ontap/
- VMware: https://galaxy.ansible.com/ui/repo/published/community/vmware/
Because a number of manual tasks need to be executed between running the Ansible playbooks, the CVD document should be used as a guide for running the playbooks. Commentary is included in the variable files to guide filling in those values.
In this version of the FlexPod setup, FC boot with FC-NVMe and NFS is configured by default in the variable files, but iSCSI boot and NVMe-TCP with NFS can also be used. The steps for setting up a FlexPod with FC boot with FC-NVMe and NFS storage protocols are:
- Create a directory and clone the repository from Github with "git clone https://github.com/ucs-compute-solutions/FlexPod-Security-Hardening.git".
- Fill in the variable files according to the CVD.
- Follow the manual steps in the CVD to set up the Nexus switches on the network and ssh into each switch.
- Execute the Nexus playbook with "ansible-playbook ./Setup_Nexus.yml -i inventory" to setup the Nexus switches.
- Follow the manual steps in the CVD to add timezone information to the Nexus switches.
- Follow the manual steps in the CVD to get the NetApp storage cluster on the network.
- Execute the NetApp storage playbook with "ansible-playbook -i inventory Setup_ONTAP.yml -t ontap_config_part_1".
- Query the Infra-SVM iSCSI IQN and add to the "all.yml" file.
- Follow the manual steps in the CVD to create an Intersight Account, and get the Cisco UCS Fabric Interconnects (FIs) on the network in Intersight Managed Mode.
- Claim the FIs into Intersight and setup and deploy the Domain Profile.
- Execute the IMM playbooks with "ansible-playbook ./Setup_IMM_Pools.yml", "ansible-playbook ./Setup_IMM_Server_Policies.yml", and "ansible-playbook ./Setup_IMM_Server_Profile_Templates.yml" to setup the Cisco UCS Server Profile Templates, Policies, and Pools.
- Follow the manual steps in the CVD to create UCS IMM server profiles for three or more VMware ESXi management hosts.
- Query the ESXi host IQNs or WWPNs from the server profiles and add to the "all.yml" file.
- If configuring Fibre Channel, follow the manual steps in the CVD to set up the MDS switches on the network and ssh into each switch.
- If configuring Fibre Channel, execute the MDS playbook with "ansible-playbook ./Setup_MDS.yml -i inventory".
- If configuring Fibre Channel, follow the manual steps in the CVD to add timezone information to the MDS switches.
- Execute the NetApp storage playbook with "ansible-playbook -i inventory Setup_ONTAP.yml -t ontap_config_part_2" to create and map the ESXi boot LUNs.
- Follow the manual steps in the CVD to install VMware ESXi and assign IPs on the three (or more) host servers using Cisco Intersight OS Install.
- Execute the ESXi playbook with "ansible-playbook ./Setup_ESXi.yml -i inventory" to setup the ESXi hosts.
- Bring a vCenter into the environment by either installing vCenter on the first ESXi host according to the CVD, copying it in, or establishing L3 routing to it.
- Setup the vCenter and add the three or more ESXi hosts to it by executing "ansible-playbook ./Setup_vCenter.yml -i inventory".
- Follow the manual steps in the CVD to complete setting up vCenter and the ESXi hosts.
- Execute the NetApp storage playbook with "ansible-playbook -i inventory Setup_ONTAP.yml -t ontap_config_part_3" to setup NVMe-TCP and finalize ONTAP Storage.
- Execute the NetApp storage playbook with "ansible-playbook -i inventory Setup_ONTAP.yml -t ontap_security_hardening_config" to setup ONTAP Storage with security best practices.
- Execute the manual steps in the CVD to complete the NVMe-TCP setup.
- Follow the steps in the CVD to install the ONTAP Tools VM via Ansible.
- Follow the steps in the CVD to install the SnapCenter VMware Plug-In via Ansible.
- Follow the steps in the CVD to install Active IQ Unified Manager via Ansible.
- Follow the manual steps in the CVD to finish setting up ONTAP tools, the SnapCenter Plug-in, and AIQUM.
- Follow the manual steps in the CVD to setup Cisco Intersight Assist and Cisco Nexus Dashboard Fabric Controller (NDFC) SAN.
The Ansible playbooks and CVD are structured in a way that a Fibre Channel Boot, Fibre Channel Boot with FC-NVMe, iSCSI Boot or iSCSI Boot with NVMe-TCP FlexPod or combination configurations can be setup by adjusting the variables. Also, the playbooks can be used to setup the following topology utilizing Cisco Nexus switches that support SAN Switching (93180YC-FX, 93360YC-FX2, or 9336C-FX2-E) for both LAN and SAN switching and FCoE Uplinks from the FIs to the switches.