K8s - Features
There are 3 possible topologies of K8s cluster provided by cegedim.cloud:
Standalone: workloads are deployed in a single data center with no disaster recovery plan.
Standard: workloads are still deployed in a single data center, but protected against data center disaster using a secondary data center as failover.
High Availability: workloads are deployed in two datacenters and no interruption of services when data center disaster can be obtained with well distributed multi-replicas deployment.
Topologies
Compute topology
cegedim.cloud provides a compute topology based on :
Region : a pair of data centers
Area : infrastructure network isolation between tenants
Availability Zones : inside an area, isolated infrastructure for Compute and Storage
Kubernetes clusters topologies
Kubernetes clusters can be deployed using 2 topologies :
Topology | Datacenters of Masters | Datacenters of workers | Worker Availability Zones | Cluster Availability Zones | Disaster Recovery Protection | Recovery Time Objective (RTO) |
---|---|---|---|---|---|---|
Standard | 1 | 1 | 2 | 2 | 4h | |
High Availability | 3 | 2 | 3 | 4 | 0 - 5 min |
Based on your requirements in terms of RTO and costs, you can choose the best topology for your needs.
Availability of topologies
Topology | EB-EMEA | EB-HDS | ET-EMEA | ET-HDS |
---|---|---|---|---|
Standard | ||||
High Availability |
For more details about the High Availability topology, please follow this page How to configure deployments to leverage HA capabilities.
Topology Keys
cegedim.cloud uses standard topology keys :
Key | Component |
---|---|
topology.kubernetes.io/region | Region |
topology.kubernetes.io/zone | Availability Zone |
kubernetes.io/hostname | FQDN of node |
Since Kubernetes > 1.20 failure-domain.beta.kubernetes.io/zone is deprecated but still remained available if pre-existing.
Only topology.kubernetes.io/zone will be officially maintained
Components and Versions
Here is the list of the components and tools that are deployed in a standard delivered cluster :
Features | Versions |
---|---|
Rancher | 2.7.6 |
Kubernetes | 1.26 |
Ingress controllers NGINX | 1.9.0 |
Prometheus | 2.38.0 |
Grafana | 9.1.5 |
Helm | 3.11.3 |
CSI Ceph | 3.9.0 |
Node OS | Ubuntu 20.04 |
CNI - canal (Calico+Flannel) | 3.25 |
Docker | 20.10.8 |
Network Architecture
Here is a figure with all network components explained :
Outgoing requests
Two pods of 2 namespaces that belong to the same Rancher Project can fully communicate between them.
Two pods of 2 namespaces that belong to two different Rancher Project cannot communicate unless user defines a Network Policy dedicated for this need.
Pods from Rancher Project named System can communicate to pods from other Rancher Projects.
Pods can only send requests to servers of the same VLAN, unless a specific network opening rule is configured between the two VLANs.
Pods cannot send requests to Internet unless, a proxy is setup inside the pod or specific network opening rule is configured for the related VLAN.
Incoming requests
Requests toward kube api-server can be reverse-proxied by Rancher URL.
Workload hosted by pods cannot be directly accessible from outside of K8S cluster, but via ingress layer for HTTP protocol or via a NodePort service for TCP protocol with a respective Load Balancer.
Ingress Controller : nginx
nginx is the ingress controller deployed to expose your workloads. You can find relevant documentation on official Github.
Two ingress controllers are deployed :
One exposing to internal Cegedim Network
nginx ingress controller
listening on every worker node on the port :80
this is the default ingress class (no ingress class needs to be specified)
One exposing to internet
nginx ingress controller - you can request to have nginx external ingress controller
listening to every worker node on the port :8081
this ingress class is : nginx-ext
using the annotation : kubernetes.io/ingress.class: "nginx-ext"
Load Balancing, DNS and Certificates
A K8s cluster comes with :
An Elastic Secured Endpoint, managed by F5 appliances, exposing the K8s workload to the cegedim internal network (once you're connected to Cegedim LAN, either physically or through VPN)
A *.<yourclustername>.ccs.cegedim.cloud DNS resolution to this endpoint
A *.<yourclustername>.ccs.cegedim.cloud SSL certificate configured
Requesting specific configuration
You can use ITCare in case of a need of a specific configuration :
Exposing your workloads to the Internet or private link
Using a specific FQDN to deploy your workload
Using a specific certificate to deploy your workload
Using Traefik as Ingress Provider instead of nginx
Adding other Ingress Providers
Accessing resources outside of cluster
Cluster Hardening
For more information regarding the hardening of Kubernetes, please follow this page Hardening.
Persistent Storage
For more information regarding the persistant solution available for cegedim.cloud's Kubernetes clusters, please follow this page Persistent Storage.
Last updated