New and Changed Information
The following table provides an overview of the significant changes up to this current release. The table does not provide an exhaustive list of all changes or of the new features up to this release.
Cisco ACI CNI Release Version |
Feature |
Description |
---|---|---|
5.2.3.3 |
Rancher support with Cisco ACI Container Network Interface (CNI) for Kubernetes 1.22 or later. |
You can integrate Rancher with Cisco ACI to simplify the management of Kubernetes clusters. |
Cisco ACI and Rancher Integration
Rancher is a software stack that simplifies the management of containers. Rancher includes the Rancher Kubernetes Engine (RKE), a certified Kubernetes distribution. It operates within platform-independent Docker containers, simplifying installation and providing consistent management of Kubernetes across all platforms. You can install and manage Kubernetes on VMware clusters, bare-metal servers, and on VMs in clouds—regardless of whether the clouds support Kubernetes service.
This document provides an introduction to Rancher and instructions for integrating it with Cisco ACI. It is assumed that you are familiar with the Cisco ACI CNI plug-in and Kubernetes.
This document describes the integration details for Cisco ACI Release 5.2(3), or later, with ACI CNI release 5.2.3.3 using RKE 1.3.13. The document also has information about importing the installed clusters to Rancher 2.6.8 or later.
Rancher Architecture
Rancher contains several key components that enable you to install and maintain Kubernetes clusters. They include Rancher Kubernetes Engine (RKE), Rancher server, and cluster and node agents.
This section describes key components of Rancher. For details, see, Rancher 2.6: Technical Architecture, and other content on the Rancher website.
Rancher Kubernetes Engine
RKE is Kubernetes distribution certified by the Cloud Native Computing Foundation (CNCF). It runs entirely within Docker containers. You use RKE to install Kubernetes on VMware clusters, bare metal servers, and VMs on clouds, including clouds that do not support Kubernetes.
Rancher server
The Rancher server contains several components that manage the entire Rancher deployment:
-
Rancher API server: The Rancher API server is the foundation for all Rancher server controllers. All Rancher-specific resources that are created using Rancher API are translated to custom resources definition (CRD) objects. Rancher controllers manage the lifecycle of the objects.
-
Management controller: Management controllers perform the activities that occur at the Rancher server level that are not specific to an individual cluster. Such activities include configuring access policies to clusters and projects and managing the global-level catalog.
-
User cluster controller: User cluster controllers perform activities specific to a cluster. For horizontal scaling, user cluster controllers are distributed across the Rancher server pods. Cluster-specific activities include managing workloads and applying roles and bindings that are defined in global policies.
-
Authentication proxy:
The authentication proxy proxies all Kubernetes API calls. It integrates with local authentication, Active Directory, and GitHub. For every Kubernetes API call, the proxy authenticates the caller and sets the correct Kubernetes impersonation headers. It forwards the call to the Kubernetes master nodes.
Rancher agents
Rancher deploys agents into Kubernetes nodes and clusters:
-
Cluster agent: Rancher deploys one cluster agent for each managed Kubernetes cluster. The cluster agent opens a web-socket tunnel to the Rancher server so the user cluster controllers and authentication proxy can communicate with the user cluster Kubernetes API server.
-
Node agent: RKE uses node agents primarily to deploy components during initial installation and subsequent upgrades. The node agents are installed also on cloud Kubernetes clusters to provide extra functions, such as fallback for cluster agents and proxy for the kubectl shell.
Prerequisites for Integrating Rancher
Complete the following tasks before integrating Rancher, following the referenced procedures on the Rancher and Cisco websites.
-
Configure the following:
-
A Cisco Application Centric Infrastructure (ACI) tenant
-
An attachable entity profile (AEP)
-
A VRF
-
A Layer 3 outside connection (L3Out)
-
A Layer 3 external network for the cluster you plan to provision with RKE
-
-
Install the Cisco ACI CNI tools from the Cisco Download site for the specific Linux distribution on a tools server that you will use to provision the cluster.
This server must have SSH access and reachability to all nodes in the cluster that you will provision.
-
Prepare the nodes for Cisco ACI Container Network Interface (CNI) plug-in installation.
Follow the procedures in Cisco ACI and Kubernetes Integration on Cisco.com until the end of the section, Preparing the Kubernetes Nodes. Use the flavor
RKE-1.3.13
. Perform the steps for the cluster and every node in the cluster.
Note
ACI CNI in nested mode is only supported with VMM-integrated VMware (with Distributed Virtual Switch).
-
Prepare the nodes for the Rancher server nodes.
Fulfill the hardware, software, and networking requirements for the nodes where you will install the Rancher server. See the page Installation Requirements for Rancher 2.x on the Rancher website.
-
Prepare the nodes in the user cluster.
Fulfill the requirements for the nodes where you will install apps and services. See the page Node Requirements for User Clusters or Rancher 2.x on the Rancher website.
Integrating Rancher
We recommended that you install Rancher server in a separate cluster, which is called a Rancher server cluster. This cluster creates and manages other clusters, which are called user clusters.
You typically install the Rancher server cluster using Rancher Kubernetes Engine (RKE). The integration with Cisco ACI supports creating a custom cluster on an on-premises deployment and creating one cluster per tenant.
This section includes prerequisites and instructions for integrating Rancher.
Install Kubernetes Using RKE
Before you begin
Fulfill the requirements in the section Prerequisites for Integrating Rancher.
Procedure
Step 1 |
Install the RKE binary file on the tools server. Follow the procedure "Download the RKE Binary" on the RKE Kubernetes Installation page on the Rancher.com website. |
||
Step 2 |
Install Docker on all the cluster nodes. Follow the guidelines and procedure in "Requirements" in the "RKE" section of the Rancher.com website. |
||
Step 3 |
Run acc_provision to generate the network provider section of the cluster.yml file that the RKE requires. See the section "Provisioning Cisco ACI to Work with Kubernetes" in Cisco ACI and Kubernetes Integration on Cisco.com. Example:
|
||
Step 4 |
Edit the input file that was generated by the previous step to match your cluster: Example:
The command generates the network-provider file that use in step 6. |
||
Step 5 |
Use RKE to generate a sample cluster.yml file and edit the file to add the cluster nodes. Alternatively, you can use an existing cluster.yml file. |
||
Step 6 |
Replace the network provider section in the cluster.yml file that you generated with the acc_provision command. The following text provides an example of a network-provider file: Example:
The configuration parameters are the same as in the acc_provision input file. The pod subnet is a main configuration option, called cluster_cidr, in the cluster.yml file. The installation defaults to 5.2.3.2.1d150da image tag for the ACI-CNI images. The latest released tag is 5.2.3.3.1d150da
and can be picked up adding the following configuration to the
|
||
Step 7 |
Enter the following command: rke up. The command internally generates the Cisco ACI Container Network Interface (CNI) .yaml file and applies it. The resulting .yml file is stored as configmap in kube-system/rke-network-plugin. |
What to do next
User can import the RKE cluster into the Rancher server. Follow the procedure Importing Existing Clusters into Rancher for Rancher 2.x on the Rancher website.
Upgrade Kubernetes Using RKE
You can use Rancher Kubernetes Engine (RKE) to upgrade Kubernetes.
Before you begin
-
Ensure that the version of Kubernetes that you want to upgrade to is supported for your environment. See the Cisco ACI Virtualization Compatibility Matrix and All Supported Versions on the Rancher website.
-
Take a backup of cluster.rkestate and cluster.yml and a snapshot of etcd.
Follow the instructions in One-time Snapshots for RKE on the Rancher website.
Note
If upgrade fails for any reason, you can use the snapshot and backed-up files to roll back to the previous version of Kubernetes. See Restoring from Backup for RKE on the Rancher website.
Procedure
Step 1 |
Update the cluster.yml file with the desired version of Kubernetes by revising the line |
Step 2 |
Enter the following command: rke up. The command internally generates the Cisco ACI Container Network Interface (CNI) .yaml file and applies it. The resulting .yml file is stored as configmap in kube-system/rke-network-plugin. |
Related Documentation
In addition to the Rancher integration information in this document, you may want to consult the following documentation:
-
Rancher
The Rancher.com website provides documentation, videos, infographics, and white papers, including Rancher: Technical Architecture.
-
Kubernetes
The Kubernetes.io website provides conceptual information, tutorials, task-based information, and reference material.
-
Cisco ACI CNI
See the following on Cisco.com: