Skip to content

Latest commit

 

History

History
 
 

edge-clusters

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

Edge clusters for Telco

Introduction

This is an example to demonstrate how to deploy an edge cluster for Telco using SUSE ATIP and the fully automated directed network provisioning.

There are two steps to deploy an edge cluster:

  • Create the image for the edge cluster using the Edge Image Builder in order to prepare all the packages dependencies and the requirements for the edge cluster.
  • Deploy the edge cluster using metal3 and the image created in the previous step.

Important notes:

  • In the following examples, we will assume that the management cluster is already deployed and running. If you want to deploy the management cluster, please refer to the Management Cluster example.
  • In the following examples, we are assuming that the edge cluster will use Baremetal Servers. If you want to deploy the full workflow using virtual machines, please refer to the metal3-demo repo

Create the image for the edge cluster

Prerequisites

Using the example folder telco-examples/edge-clusters/dhcp/eib or telco-examples/edge-clusters/dhcp-less/eib (depending on your use case related to dhcp or static ips), we will create the basic structure in order to build the image for the edge cluster:

You need to modify the following values in the telco-edge-cluster.yaml file:

  • ${ROOT_PASSWORD} - The root password for the management cluster. This could be generated using openssl passwd -6 PASSWORD and replacing PASSWORD with the desired password, and then replacing the value in the telco-edge-cluster.yaml file.
  • ${SCC_REGISTRATION_CODE} - The registration code for the SUSE Customer Center for the SLE Micro product. This could be obtained from the SUSE Customer Center and replacing the value in the telco-edge-cluster.yaml file.

You need to modify the following folder:

  • base-images - To include inside the SL-Micro.x86_64-6.0-Base-RT-GM2.raw image downloaded from the SUSE Customer Center.

Building the Edge Cluster Image using EIB

All the following commands in this section could be executed using any linux laptop/server x86_64 with podman installed. You don't need to have a specific environment to build the image.

Generate the image with our configuration for Telco profile

$ cd telco-examples/edge-clusters
$ sudo podman run --rm --privileged -it -v $PWD:/eib \
registry.suse.com/edge/3.1/edge-image-builder:1.1.0 \
build --definition-file telco-edge-cluster.yaml

Deploy the Edge Clusters

Once the image has been built, an Edge cluster can be deployed from the management cluster by leveraging one of the examples available in this repository, which cover different possible scenarios and requirements, from single node cluster, to multi-node and clusters with telco specific network configurations and tuning. We recommend starting from the following two examples (also detailed below):

Additional examples cover the use of IPv4 and IPv6, or IPv6 only, and can be found following the link for the required combination:

Single Node Single Node Multi-node Multi-node
Dual-stack IPv6 only Dual-stack IPv6 only
DHCP README README WIP WIP
DHCP-less README README WIP WIP

Note: multi-node examples are currently being worked on and will be available soon.

For all the examples, there are 2 options available to be used depending on your environment:

  • DHCP Environment: In case you are using a DHCP environment, you need to use the telco-examples/edge-clusters/dhcp folder.
  • Advanced Network configuration: In case you are using a DHCP-less or advanced networking like VLAN, bond, etc..., you need to use the telco-examples/edge-clusters/dhcp-less folder.

Example 1 - Deploy a single-node Edge Cluster with the image generated and Telco profiles

There are 2 steps to deploy a single-node edge cluster with all Telco Capabilities enabled:

  • Enroll the new Baremetal host in the management cluster.
  • Provision the new host using the CAPI manifests and the image generated in the previous step. There are two possible manifests to be used depending on the deep knowledge of the network interfaces (PCI-Address, Vendor, DeviceID, pfNames) you may have previous to deploy the baremetal:
    • telco-capi-single-node.yaml: This manifest is a template to be used in case you have the deep knowledge of the network interfaces like (PCI-Address, Vendor, DeviceID, pfNames) or you want to use FEC interfaces like ACC100.
    • telco-capi-single-node-sriov-auto.yaml: This manifest is a template to be used in case you don't have the deep knowledge of the network interfaces. You will only need to know the interface name, and the number of VFs to be used.

The prefered option is to use the telco-capi-single-node-sriov-auto.yaml manifest, but in case you have the deep knowledge of the network interfaces or you need to use FEC accelerator card, you could use the telco-capi-single-node.yaml manifest.

All the following steps have to be executed from the management cluster in order to deploy the edge clusters.

Enroll the new Baremetal host

Using the folder telco-examples/dhcp/edge-telco-single-node or telco-examples/dhcp-less/edge-telco-single-node (depending on your use case related to dhcp or static ips), we will create the components required to deploy a single-node edge cluster using the image generated in the previous step and the telco profiles configured.

The first step is to enroll the new Baremetal host in the management cluster. To do that, you need to modify the bmh-example.yaml file and replace the following with your values:

  • ${BMC_USERNAME} - The username for the BMC of the new Baremetal host.
  • ${BMC_PASSWORD} - The password for the BMC of the new Baremetal host.
  • ${BMC_MAC} - The MAC address of the new Baremetal host to be used.
  • ${BMC_ADDRESS} - The URL for the Baremetal host BMC (e.g redfish-virtualmedia://192.168.200.75/redfish/v1/Systems/1/). If you want to know more about the different options available depending on your hardware provider, please check the following link.

In case you want to use a dhcp-less environment, you will need to configure and replace also the following parameters:

  • ${CONTROLPLANE_INTERFACE} - The control plane interface to be used for the edge cluster (e.g eth0).
  • ${CONTROLPLANE_IP} - The IP address to be used as a endpoint for the edge cluster (should match with the kubeapi-server endpoint).
  • ${CONTROLPLANE_PREFIX} - The CIDR to be used for the edge cluster (e.g 24 in case you want /24 or 255.255.255.0).
  • ${CONTROLPLANE_GATEWAY} - The gateway to be used for the edge cluster (e.g 192.168.100.1).
  • ${CONTROLPLANE_MAC} - The MAC address to be used for the control plane interface (e.g 00:0c:29:3e:3e:3e).
  • ${DNS_SERVER} - The DNS to be used for the edge cluster (e.g 192.168.100.2).

Then, you need to apply the changes using the following command into the management cluster:

$ kubectl apply -f bmh-example.yaml

The new Baremetal host will be enrolled changing the state from registering to inspecting and available. You could check the status using the following command:

$ kubectl get bmh

Provision the new host using the CAPI (with SRIOV - helm chart and automated mode vf creation) manifests and the image generated

Once the new Baremetal host is available, you need to provision the new host using the CAPI manifests and the image generated in the previous step.

The first thing is to modify the telco-capi-single-node-sriov-auto.yaml file and replace the following with your values:

  • ${EDGE_CONTROL_PLANE_IP} - The IP address to be used as a endpoint for the edge cluster (should match with the kubeapi-server endpoint).
  • ${RESOURCE_NAME1} - The resource name to be used in order to identify the VFs to be used for the workloads in Kubernetes.
  • ${SRIOV-NIC-NAME1} - The network interface to be used for creating the VFs (e.g eth0 which means the first network interface in the server. You can get that info using ip link command to list the network interfaces).
  • ${PF_NAME1} - The network interface or physical function (usually filters in the network interface) to be used for the SRIOV.
  • ${DRIVER_NAME1} - The driver to be used for the interface and VFs (e.g vfio-pci).
  • ${NUM_VFS1} - The number of VFs to be created for the network interface (e.g 2).
  • ${ISOLATED_CPU_CORES} - The isolated CPU cores to be used for workloads pinning some specific cpu cores. You could get that info using lscpu command to list the CPU cores and then, select the cores to be used for the edge cluster in case you need cpu pinning for your workloads. For example, 1-18,21-38 could be used for the isolated cores.
  • ${NON-ISOLATED_CPU_CORES} - The cores listed could be used shared for the rest of the process running on the edge cluster. For example, 0,20,21,39 could be used for the non-isolated cores.
  • ${CPU_FREQUENCY} - The frequency to be used for the CPU cores. For example, 2500000 represents 2.5Ghz configuration and it could be used to set the CPU cores to the max performance.

You can also modify any other parameter in the telco-capi-single-node.yaml file to match with your requirements e.g. DPDK configuration, number of VFs to generate, number of SRIOV interfaces, etc. This is basically a template to be used for the edge cluster deployment.

** Note: Remember to locate the eibimage-slmicro60rt-telco.raw file generated in Create the image for the edge cluster into the management cluster httpd cache folder to be used during the edge cluster provision step.

Then, you need to apply the changes using the following command into the management cluster:

$ kubectl apply -f telco-capi-single-node.yaml

Provision the new host using the CAPI (with SRIOV - device plugin and config map) manifests and the image generated

Once the new Baremetal host is available, you need to provision the new host using the CAPI manifests and the image generated in the previous step.

The first thing is to modify the telco-capi-single-node.yaml file and replace the following with your values:

  • ${EDGE_CONTROL_PLANE_IP} - The IP address to be used as a endpoint for the edge cluster (should match with the kubeapi-server endpoint).
  • ${SRIOV_VENDOR} - The vendor of the SRIOV network device to be used (e.g 8086 which means intel. You can get that info using lspci command with grep to find the vendors and device codes). For more information, please check the following link
  • ${SRIOV_DEVICE} - The device of the SRIOV network device to be used (e.g 57c1 which means the FEC acc card. You can get that info using lspci command with grep to find the vendors and device codes). For more information, please check the following link
  • ${SRIOV_NET_INTERFACE} - The network interface to be used for the SRIOV network device (e.g eth0 which means the first network interface in the server. You can get that info using ip link command to list the network interfaces).
  • ${ISOLATED_CPU_CORES} - The isolated CPU cores to be used for workloads pinning some specific cpu cores. You could get that info using lscpu command to list the CPU cores and then, select the cores to be used for the edge cluster in case you need cpu pinning for your workloads. For example, 1-18,21-38 could be used for the isolated cores.
  • ${NON-ISOLATED_CPU_CORES} - The cores listed could be used shared for the rest of the process running on the edge cluster. For example, 0,20,21,39 could be used for the non-isolated cores.
  • ${CPU_FREQUENCY} - The frequency to be used for the CPU cores. For example, 2500000 represents 2.5Ghz configuration and it could be used to set the CPU cores to the max performance.
  • ${DPDK_PCI_ADDRESS} - The PCI device to be used for the DPDK configuration. You could get that info using lspci command to list the PCI devices and then selecting the device to be used for the DPDK configuration. For example, 0000:00:1f.6 could be used for the DPDK configuration.

You can also modify any other parameter in the telco-capi-single-node.yaml file to match with your requirements e.g. DPDK configuration, number of VFs to generate, number of SRIOV interfaces, etc. This is basically a template to be used for the edge cluster deployment.

** Note: Remember to locate the eibimage-slmicro60rt-telco.raw file generated in Create the image for the edge cluster into the management cluster httpd cache folder to be used during the edge cluster provision step.

Then, you need to apply the changes using the following command into the management cluster:

$ kubectl apply -f telco-capi-single-node.yaml

Example 2 - Deploy a multi-node HA cluster using metal3, metallb and the image generated

There are 2 steps to deploy a multi-node edge cluster:

  • Enroll the 3 Baremetal hosts in the management cluster.
  • Provision the new hosts using the CAPI manifests and the image generated in the previous step.

Enroll the new Baremetal host

Using the folder telco-examples/dhcp/edge-metallb-multi-node or telco-examples/dhcp-less/edge-metallb-multi-node (depending on your use case related to dhcp or static ips), we will create the components required to deploy a multi-node edge cluster with 3 control-plane replicas, using the image generated in the previous step and metallb as a load balancer.

The first step is to enroll the new Baremetal hosts in the management cluster. To do that, you need to modify the bmh-node1-example.yaml file and replace the following with your values:

  • ${BMC_NODE1_USERNAME} - The username for the BMC of the first Baremetal host.
  • ${BMC_NODE1_PASSWORD} - The password for the BMC of the first Baremetal host.
  • ${BMC_NODE1_MAC} - The MAC address of the first Baremetal host to be used.
  • ${BMC_NODE1_ADDRESS} - The URL for the first Baremetal host BMC (e.g redfish-virtualmedia://192.168.200.75/redfish/v1/Systems/1/). If you want to know more about the different options available depending on your hardware provider, please check the following link.

In case you want to use a dhcp-less environment, you will need to configure and replace also the following parameters:

  • ${CONTROLPLANE1_INTERFACE} - The control plane interface to be used for the edge cluster (e.g eth0).
  • ${CONTROLPLANE1_IP} - The IP address to be used as a endpoint for the edge cluster (should match with the kubeapi-server endpoint).
  • ${CONTROLPLANE1_PREFIX} - The CIDR to be used for the edge cluster (e.g 24 in case you want /24 or 255.255.255.0).
  • ${CONTROLPLANE1_GATEWAY} - The gateway to be used for the edge cluster (e.g 192.168.100.1).
  • ${CONTROLPLANE1_MAC} - The MAC address to be used for the control plane interface (e.g 00:0c:29:3e:3e:3e).
  • ${DNS_SERVER} - The DNS to be used for the edge cluster (e.g 192.168.100.2).

You need to replace the same variables (change the values respectively) for the second and third Baremetal hosts in the bmh-node2-example.yaml and bmh-node3-example.yaml files.

Then, you need to apply the changes using the following command into the management cluster:

$ kubectl apply -f bmh-node1-example.yaml 
$ kubectl apply -f bmh-node2-example.yaml 
$ kubectl apply -f bmh-node3-example.yaml

The new Baremetal hosts will be enrolled changing the state from registering to inspecting and available. You could check the status using the following command:

$ kubectl get bmh -owide

Provision the new hosts using the CAPI manifests and the image generated

Once the new Baremetal hosts are available, you need to provision the new hosts using the CAPI manifests and the image generated in the previous step.

The first thing is to modify the telco-capi-metallb-multi-node.yaml file and replace the following with your values:

  • ${EDGE_VIP_ADDRESS} - The IP address to be used as a endpoint for the edge cluster (should be the VIP address reserved previously).

** Note: Remember to locate the eibimage-slmicro60rt-telco.raw file generated in Create the image for the edge cluster into the management cluster httpd cache folder to be used during the edge cluster provision step.

Then, you need to apply the changes using the following command into the management cluster:

$ kubectl apply -f telco-capi-single-node.yaml