Introduction to Kubernetes
Kubernetes is an open-source container orchestration platform that automates the deployment, scaling, and management of containerized applications. It helps manage workloads efficiently, ensuring high availability and scalability.
Key Concepts in Kubernetes
- Cluster: A set of nodes (machines) that run containerized applications.
- Node: A single machine in a Kubernetes cluster (physical or virtual).
- Pod: The smallest deployable unit in Kubernetes, which contains one or more containers.
- Service: An abstraction that defines a logical set of Pods and a policy to access them.
- Deployment: Manages the desired state of Pods and ReplicaSets.
- ConfigMap and Secret: Store configuration data and sensitive information, respectively.
- Namespace: Provides a way to divide cluster resources among multiple users.
- Ingress: Manages external access to services in a cluster, typically HTTP.
Setting Up Kubernetes on Google Cloud
Step 1: Prerequisites
- A Google Cloud account. Sign up here.
- Install the Google Cloud CLI (gcloud) on your local machine. Install gcloud CLI.
- Install kubectl (Kubernetes CLI):
gcloud components install kubectl
Step 2: Create a Google Kubernetes Engine (GKE) Cluster
Using the Google Cloud Console:
- Go to the Google Kubernetes Engine page.
- Click Create Cluster.
- Choose the cluster type (e.g., Standard or Autopilot).
- Configure the cluster settings, such as the number of nodes, machine type, and location (zone/region).
- Click Create to provision the cluster.
Using the Command Line:
- Enable the Kubernetes Engine API:
gcloud services enable container.googleapis.com
- Create a GKE Cluster:
gcloud container clusters create my-cluster --zone us-central1-a --num-nodes=3
Replace my-cluster
with your desired cluster name and us-central1-a
with your preferred zone.
- Authenticate kubectl with the cluster:
gcloud container clusters get-credentials my-cluster --zone us-central1-a
Step 3: Verify the Cluster
- Check the cluster nodes:
kubectl get nodes
- You should see a list of nodes indicating the cluster is up and running.
Basic Kubernetes Operations
1. Deploy an Application
Using the Google Cloud Console:
- Navigate to the Workloads tab in the Kubernetes Engine section.
- Click Deploy.
- Specify the container image (e.g.,
gcr.io/google-samples/hello-app:1.0
). - Configure the deployment settings (e.g., replicas, namespace).
- Click Deploy.
Using kubectl:
- Create a Deployment:
kubectl create deployment hello-app --image=gcr.io/google-samples/hello-app:1.0
- Expose the Deployment as a Service:
kubectl expose deployment hello-app --type=LoadBalancer --port=80 --target-port=8080
- Get the external IP of the Service:
kubectl get service hello-app
- Access the application using the external IP.
2. Scale the Application
Using the Google Cloud Console:
- Go to the Workloads tab.
- Click on the Deployment you want to scale.
- Adjust the number of replicas and click Save.
Using kubectl:
- Scale the Deployment to 3 replicas:
kubectl scale deployment hello-app --replicas=3
- Verify the scaling:
kubectl get pods
3. Update the Application
Using the Google Cloud Console:
- Go to the Workloads tab.
- Click on the Deployment you want to update.
- Edit the container image to the new version (e.g.,
gcr.io/google-samples/hello-app:2.0
). - Click Save to initiate the update.
Using kubectl:
- Update the image version:
kubectl set image deployment/hello-app hello-app=gcr.io/google-samples/hello-app:2.0
- Monitor the rollout status:
kubectl rollout status deployment/hello-app
4. Delete Resources
Using the Google Cloud Console:
- Navigate to the Workloads or Services & Ingress tab.
- Select the resource you want to delete.
- Click Delete and confirm.
Using kubectl:
- Delete the Service:
kubectl delete service hello-app
- Delete the Deployment:
kubectl delete deployment hello-app
Advanced Topics
ConfigMaps and Secrets
Using the Google Cloud Console:
- Go to the ConfigMaps or Secrets tab under Kubernetes Engine.
- Click Create and fill in the required details.
Using kubectl:
- ConfigMap example:
kubectl create configmap my-config --from-literal=key1=value1
- Secret example:
kubectl create secret generic my-secret --from-literal=password=12345
Helm Charts
- Helm is a package manager for Kubernetes.
- Install Helm:
curl https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3 | bash
- Use Helm to deploy applications:
helm repo add bitnami https://charts.bitnami.com/bitnami
helm install my-release bitnami/nginx
Monitoring and Logging
Using the Google Cloud Console:
- Go to the Operations tab in the Cloud Console.
- Use Metrics Explorer to monitor cluster performance.
- Access logs under Logging > Log Explorer to view system and workload logs.
Using gcloud CLI:
- Enable logging for your cluster:
gcloud container clusters update my-cluster --logging=SYSTEM,WORKLOAD --monitoring=SYSTEM
Cleaning Up
Using the Google Cloud Console:
- Navigate to the Kubernetes Engine page.
- Select the cluster you want to delete.
- Click Delete and confirm.
Using gcloud CLI:
- Delete the GKE cluster to avoid incurring costs:
gcloud container clusters delete my-cluster --zone us-central1-a
Additional Resources
- Kubernetes Official Documentation
- Google Cloud Kubernetes Engine Documentation
- Kubernetes Hands-On Tutorials
By following this guide, you can learn Kubernetes basics and effectively use it with Google Cloud, both locally and through the Google Cloud Console. Expand your knowledge by exploring advanced features and best practices.