ReplicaSets
This article explains Kubernetes replication controllers and ReplicaSets, focusing on their roles in maintaining high availability and load balancing in clusters.
Introducing ReplicaSet¶
A ReplicaSet is a modern alternative to the replication controller, using an updated API version and some improvements. Here are the key differences:
- API Version: Use
apps/v1for a ReplicaSet. - Selector: In addition to metadata and specification, a ReplicaSet requires a
selectorto explicitly determine which pods to manage. This is defined usingmatchLabels, which can also capture pods created before the ReplicaSet if they match the criteria.
Below is an example ReplicaSet definition:
- Labels du replicaSet
- Labels des pods
Create the ReplicaSet with:
Then, verify its creation:
And view the associated pods:
kubectl get pods
NAME READY STATUS RESTARTS AGE
app01-replicaset-4dpd8 1/1 Running 0 17s
app01-replicaset-fzwmj 1/1 Running 0 17s
app01-replicaset-x9s8z 1/1 Running 0 17s
Labels and Selectors¶
Labels in Kubernetes are critical because they enable controllers, such as ReplicaSets, to identify and manage the appropriate pods within a large cluster. For example, if you deploy multiple instances of a front-end web application, assign a label (e.g., tier: front-end) to each pod. Then, use a selector to target those pods:
The pod definition should similarly include the label:
This label-selector mechanism ensures that the ReplicaSet precisely targets the intended pods and maintains the set number of replicas by replacing any failed pods.
Is the Template Section Required?¶
Even if three pods with matching labels already exist in your cluster, the template section in the ReplicaSet specification remains essential. It serves as the blueprint for creating new pods if any fail, ensuring the desired state is consistently maintained.
Scaling the ReplicaSet¶
Scaling a ReplicaSet involves adjusting the number of pod replicas. There are two methods to achieve this:
- Update the Definition File
Modify the replicas value in your YAML file (e.g., change from 3 to 6) and update the ReplicaSet with:
Note
1️⃣ kubectl replace -f replicaset-definition.yml
Remplace entièrement la ressource existante par ce qui est dans le fichier YAML. Tout ce qui n’est pas dans le fichier sera supprimé ou remis aux valeurs par défaut. Exemple : si ton YAML ne contient pas certaines annotations ou labels qui étaient sur le ReplicaSet existant, ils seront perdus. kubectl replace -f replicaset-definition.yml
2️⃣ kubectl apply -f replicaset-definition.yml Fait une mise à jour déclarative. Kubernetes compare ce qui est dans le fichier YAML avec la ressource actuelle et modifie seulement ce qui a changé. Les champs non mentionnés dans le YAML restent inchangés. C’est la méthode recommandée pour gérer des ressources en production, car elle est moins disruptive. kubectl apply -f replicaset-definition.yml
- Use the kubectl scale Command
Scale directly from the command line:
kubectl scale --replicas=6 -f replicaset-definition.yml
kubectl scale replicaset app01-replicaset --replicas=6
kubectl scale command, the YAML file still reflects the original number of replicas. To maintain consistency, it may be necessary to update the YAML file after scaling.
Common Commands Overview¶
Below is a quick reference table summarizing some useful commands when working with replication controllers and ReplicaSets:
| Resource Type | Use Case | Example Command |
|---|---|---|
| Create Object | Create from a definition file | kubectl create -f <filename> |
| View ReplicaSets/RC | List replication controllers | kubectl get replicaset or kubectl get replicationcontroller |
| Delete ReplicaSet/RC | Remove a replication controller | kubectl delete replicaset <replicaset-name> |
| Update Definition | Replace object using YAML file | kubectl replace -f <filename> |
| Scale ReplicaSet/RC | Change number of replicas | kubectl scale --replicas=<number> -f <filename> |