Last updated
Last updated
A Deployment named nginx-deployment
is created, indicated by the .metadata.name
field.
The Deployment creates three replicated Pods, indicated by the .spec.replicas
field.
The .spec.selector
field defines how the Deployment finds which Pods to manage. In this case, you select a label that is defined in the Pod template (app: nginx
). However, more sophisticated selection rules are possible, as long as the Pod template itself satisfies the rule.
Before you begin, make sure your Kubernetes cluster is up and running. Follow the steps given below to create the above Deployment:
Create the Deployment by running the following command:
Run kubectl get deployments
to check if the Deployment was created.
When you inspect the Deployments in your cluster, the following fields are displayed:
NAME
lists the names of the Deployments in the namespace.
READY
displays how many replicas of the application are available to your users. It follows the pattern ready/desired.
UP-TO-DATE
displays the number of replicas that have been updated to achieve the desired state.
AVAILABLE
displays how many replicas of the application are available to your users.
AGE
displays the amount of time that the application has been running.
Notice how the number of desired replicas is 3 according to .spec.replicas
field.
Notice that the Deployment has created all three replicas, and all replicas are up-to-date (they contain the latest Pod template) and available.
To see the ReplicaSet (rs
) created by the Deployment, run kubectl get rs
.
The output is similar to this:
To see the labels automatically generated for each Pod.
Assume that today we'd like to scale our nginx Pods from two to four: