Skip to content

Latest commit

 

History

History
95 lines (74 loc) · 2.94 KB

File metadata and controls

95 lines (74 loc) · 2.94 KB

ReplicationController

Before using kubectl, please set the KUBECONFIG environment variable to point to the right kubeconfig file.

$ export KUBECONFIG=../02-Multi-node_cluster/vagrant/kubeconfig.yaml

The Replication Controller is the original form of replication in Kubernetes. It’s being replaced by Replica Sets.

A Replication Controller is a structure that enables you to easily create multiple pods, then make sure that that number of pods always exists. If a pod does crash, the Replication Controller replaces it.

If there are too many pods, the ReplicationController terminates the extra pods. If there are too few, the ReplicationController starts more pods. Unlike manually created pods, the pods maintained by a ReplicationController are automatically replaced if they fail, are deleted, or are terminated.

Create the RC

$ kubectl create -f nginx-rc.yaml
replicationcontroller/nginx created

Get informations about the RC

$ kubectl get rc                                                       
NAME    DESIRED   CURRENT   READY   AGE
nginx   2         2         0       69s

Describe the RC

$ kubectl describe rc/nginx
Name:         nginx
Namespace:    default
Selector:     app=nginx
Labels:       app=nginx
Annotations:  <none>
Replicas:     2 current / 2 desired
Pods Status:  0 Running / 2 Waiting / 0 Succeeded / 0 Failed
Pod Template:
  Labels:  app=nginx
  Containers:
   nginx:
    Image:        nginx
    Port:         80/TCP
    Host Port:    0/TCP
    Environment:  <none>
    Mounts:       <none>
  Volumes:        <none>
Events:
  Type    Reason            Age   From                    Message
  ----    ------            ----  ----                    -------
  Normal  SuccessfulCreate  24s   replication-controller  Created pod: nginx-c7nw7
  Normal  SuccessfulCreate  24s   replication-controller  Created pod: nginx-j7swj

Get the Pods

$ kubectl get pods                                                     
NAME          READY   STATUS    RESTARTS   AGE
nginx-c7nw7   1/1     Running   0          8s
nginx-j7swj   1/1     Running   0          8s

Now try to delete a Pod, you will see the RC that suddenly recreate another instance of the same Pod template.

$ kubectl delete pod nginx-c7nw7                                         
pod "nginx-c7nw7" deleted

RC successfully ensured the derired number of Pods (2)

$ kubectl get pods                                                      
NAME          READY   STATUS    RESTARTS   AGE
nginx-j7swj   1/1     Running   0          80s
nginx-t54sl   1/1     Running   0          16s

Finally, delete the RC

$ kubectl delete -f nginx-rc.yaml
replicationcontroller "nginx" deleted

As you can see, when you delete the Replication Controller, you also delete all of the pods that it created.

$ kubectl get pods                                                     
No resources found.