Table of Contents:
- Understanding the Technologies
- Docker: Containerization for Consistent Environments
- Kubernetes: Orchestrating Containers at Scale(kops)
- Ansible: Automating Infrastructure Configuration
- AWS Elastic Container Registry (ECR): Secure Container Image Storage
- Building and Pushing the Docker Image to AWS ECR
- Setting up Docker CLI
- Creating a Dockerfile for Nginx Application
- Building the Docker Image
- Pushing the Docker Image to AWS ECR
- Creating Ansible Role for Kubernetes Deployment
- Defining the Role Structure
- Writing Ansible Tasks for Deployment
- Configuring Kubernetes Resources (Pods, Services, etc.)
- Applying the Ansible Role to the Kubernetes Cluster
- Creating Ansible Playbook for Nginx Application Deployment
- Defining the Playbook Structure
- Including the Kubernetes Deployment Role
- Specifying Variables and Configuration
- Executing the Playbook
- Verifying the Deployment
- Accessing the Nginx Website
- Testing Load Balancing and Scalability
- Monitoring the Cluster with Kubernetes Tools
LAUNCH INSTANCE WITH T2.MICRO, 10 GB SSD, sg-ssh&all.
data:image/s3,"s3://crabby-images/17447/1744759de85182ff7686a3ad30d3405902213279" alt=""
data:image/s3,"s3://crabby-images/d5d05/d5d05a083ba1232211e0a57c5dfff02e00a6e553" alt=""
data:image/s3,"s3://crabby-images/10bda/10bda0edda02c160d21f864466df2e6b2fe59fbd" alt=""
data:image/s3,"s3://crabby-images/f2548/f25482bc712896c48a0a807b96717735b3f1c44e" alt=""
data:image/s3,"s3://crabby-images/84557/8455754e3e1fe3e1840a7028cf6dbb124e7406c5" alt=""
Now connect this workspace ec2 instance to the terminal. After connect the ec2 then update the packages
data:image/s3,"s3://crabby-images/928f3/928f3c156fe63caaa18189ec1baffc3f96b33e8a" alt=""
data:image/s3,"s3://crabby-images/6cf8a/6cf8a7452ea839bcbabaabf24389f1c68aabceb7" alt=""
Now create an IAM user of CLI, generate an access key & secret key, and give admin access. Save the access key and secret key in notepad for further use.
data:image/s3,"s3://crabby-images/5af8a/5af8a844fa07fb4d8c215f8922e77782b0d94a5d" alt=""
data:image/s3,"s3://crabby-images/af24c/af24c2deb579b8945bd6bcc13e9074829543684f" alt=""
data:image/s3,"s3://crabby-images/33044/3304490ce7fe2248f6e2e3a81b4c9a63adba3b2c" alt=""
data:image/s3,"s3://crabby-images/a31f0/a31f0ebf452f2a047184c9d07966a57852522081" alt=""
data:image/s3,"s3://crabby-images/1aa22/1aa22411bd00bed83b9e9a8d3fc40b2407117534" alt=""
Now install Aws cli.
curl "
https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip
" -o "
awscliv2.zip
"
data:image/s3,"s3://crabby-images/0d0be/0d0bee21ee3e229518b006b4b72f266fd7172162" alt=""
sudo yum install unzip
data:image/s3,"s3://crabby-images/8b290/8b2905e7df504e53ba1f73fa48c5fd5f2dd63fcf" alt=""
unzip
awscliv2.zip
data:image/s3,"s3://crabby-images/4e1dd/4e1dd013db75a0ac00df21041d542157230e07c0" alt=""
sudo ./aws/install
data:image/s3,"s3://crabby-images/f4e20/f4e209b32465524c65f063b2cd69efef8dde4087" alt=""
After installation of AWS CLI to set a path:
sudo vim .bashrc
export PATH=$PATH:/usr/local/bin/
source .bashrc
Now check the version
aws --version
data:image/s3,"s3://crabby-images/ebaf3/ebaf3991d7b51e5c99fb050d59ca536cf96eb740" alt=""
Step-2
Install Kops and Kubectl for creating clusters of k8s (master and node) from the workspace ec2 instance
sudo wget
https://github.com/kubernetes/kops/releases/download/v1.24.1/kops-linux-amd64
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
data:image/s3,"s3://crabby-images/4962d/4962dcaa3e51c5e4cb37c3612902e9e16bdad898" alt=""
Change Permissions: sudo chmod +x kops-linux-amd64 kubectl
Move Files: sudo mv kubectl /usr/local/bin/kubectl
Move Files: sudo mv kops-linux-amd64 /usr/local/bin/kops
kubectl version
kops version
data:image/s3,"s3://crabby-images/b405f/b405fc432d32667aa6a0656e907819bcafc26cf3" alt=""
Step-3
Configure AWS CLI in workspace ec2 instance for creating k8s clusters and etcd of s3 bucket using kops commands.
First, configure aws cli:
aws configure
data:image/s3,"s3://crabby-images/cd73f/cd73fbf37313821220f9261eb22bcd7b1d3e33fe" alt=""
Now create an infrastructure of k8s cluster.
first, create etcd of k8s in aws using s3 bucket as Mumbai region.
aws s3api create-bucket --bucket sana.k8s.local --region ap-south-1 --create-bucket-configuration LocationConstraint=ap-south-1
data:image/s3,"s3://crabby-images/96059/9605968955ed816915ea782bdc02cf6cf77cc774" alt=""
data:image/s3,"s3://crabby-images/a03a8/a03a8e60d63632f1eadb7d0e698d2af6200a0c5c" alt=""
Enable Bucket Version:
aws s3api put-bucket-versioning --bucket sana.k8s.local --region ap-south-1 --versioning-configuration Status=Enabled
EXPORT CLUSTER DATA INTO BUCKET:
export KOPS_STATE_STORE=s3://sana.k8s.local
GENERATE-KEY for clusters:
ssh-keygen
data:image/s3,"s3://crabby-images/62722/62722315a209273823c21077e2e83f3002d0be22" alt=""
Now create cluster from workspace instance.
kops create cluster --name sana.k8s.local --zones ap-south-1a --master-size t2.medium --node-size t2.micro
data:image/s3,"s3://crabby-images/22084/220847d354f42af265ae923918c83cdb2ad95a05" alt=""
After creating cluster if u edit ur cluster follow this suggestion:
- list clusters with:
kops get cluster
- edit this cluster with:
kops edit cluster sana.k8s.local
- edit your node instance group:
-
kops edit ig --name=sana.k8s.local nodes-ap-south-1a
- edit your master instance group:
kops edit ig --name=sana.k8s.local master-ap-south-1a
Now cluster is created and now run the cluster with help of this command.
kops update cluster --name sana.k8s.local --yes --admin
data:image/s3,"s3://crabby-images/30d75/30d7528e008a8fc9467fb9e360c190675225cd03" alt=""
data:image/s3,"s3://crabby-images/78d20/78d20f1bce5b6951608427e6c2176e5468734500" alt=""
data:image/s3,"s3://crabby-images/b626f/b626f46868a3bf77857cb339efe98491cc0e3284" alt=""
Step-4
Create Elastic Container Registry(ECR) in AWS.