DevOps Project 05
Hands-on DevOps Project 05
data:image/s3,"s3://crabby-images/7ad80/7ad80dd78ba89ea72eb29c8f36c449117c8cde50" alt=""
A new day, a new Project. Let’s learn along!😉
In the dynamic realm of cloud computing, orchestrating and deploying applications seamlessly is a necessity. This story takes you on a journey through deploying a Node.js application on Amazon Web Services (AWS) using the Elastic Container Service (ECS) Fargate and Elastic Container Registry (ECR). We’ll explore the underlying technologies, tools, and steps required to achieve this feat.
The project leverages cutting-edge technologies to bring your Node.js application to life:
- Node.js: A popular JavaScript runtime that allows you to build scalable and efficient server-side applications.
- Docker: A containerization platform that packages your application and its dependencies into isolated containers for consistent deployment.
- AWS ECS Fargate: A serverless compute engine for containers that allows you to run containers without the need to manage the underlying infrastructure.
- AWS ECR: A fully managed Docker container registry that makes it easy to store, manage, and deploy Docker container images.
Let’s start..
data:image/s3,"s3://crabby-images/69a31/69a31050c6e5737ea3a86b929c5e16da05ad213a" alt=""
Step 01:- Cloning the source code from GitHub
- Login to AWS Console and create an EC2 instance and allow port 8000 in inbound rules.
- Name: ECR_ECS, AMI: Ubuntu 22.04, type:t2.micro > Launch Instance
data:image/s3,"s3://crabby-images/26d0a/26d0a5feae3bd0b56dac8a4fd1e4493909930f41" alt=""
- Now, Connect to instance and Clone the repository from GitHub.
- https://github.com/SaurabhDahibhate/node-todo.git
data:image/s3,"s3://crabby-images/9ffbc/9ffbc31c1c281ed3170b4cebf99b72b0e4438259" alt=""
Step 02:- Create IAM user and Installation of AWS CLI and Docker.
- Create an IAM user in the AWS management console.
data:image/s3,"s3://crabby-images/9af45/9af45de40dc120c935569d485d2cdaabe55608a9" alt=""
- Select attach policies directly and write following policies .
data:image/s3,"s3://crabby-images/f840d/f840d8c9a69c4709e4e0b352ef71116b6fb352f3" alt=""
- Write the policies required for accessing the ECR.
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ecr:GetDownloadUrlForLayer",
"ecr:BatchGetImage",
"ecr-public:BatchCheckLayerAvailability",
"ecr-public:PutImage",
"ecr-public:DescribeRepositories",
"ecr-public:GetRepositoryPolicy",
"ecr:ListImages",
"ecr-public:DeleteRepository",
"ecr-public:CreateRepository",
"ecr-public:GetAuthorizationToken",
"sts:GetServiceBearerToken",
"ecr-public:InitiateLayerUpload",
"ecr-public:UploadLayerPart",
"ecr-public:CompleteLayerUpload"
],
"Resource": "*"
}
]
}
data:image/s3,"s3://crabby-images/c855a/c855a998a4d4789d20d3868cb63cea273ce8f421" alt=""
- Now search and select created policy and click on Next.
data:image/s3,"s3://crabby-images/5c66a/5c66a0285f27a711e2cfafe70fd8ba75ec7840d8" alt=""
- User is created successfully but there is not any access key that key we have to Create.
- Click on create access key.
data:image/s3,"s3://crabby-images/c4d56/c4d563a11853d304e8931b73d26d022437ecc81c" alt=""
- We want access of CLI so select Command Line Interface.
data:image/s3,"s3://crabby-images/1e356/1e35687ed5b23325091da7abcaafd71ccfbf7311" alt=""
- Access key is created successfully done.
data:image/s3,"s3://crabby-images/9d086/9d0865b51fa7f324d964f30621be0ef68ea43027" alt=""
- Install AWS cli (sudo apt install awscli)
- Install docker (Click Here for Docker installation)
data:image/s3,"s3://crabby-images/3a6dd/3a6dd25260b18ff91b27a7ab7bb517578473eb62" alt=""
- Add ubuntu user to docker group
sudo usermod -aG docker ubuntu
` - Connect the EC2 instance with AWS management console through awscli.
data:image/s3,"s3://crabby-images/597e2/597e278006ed8e3f0ef272f6e2ffd92b10777b04" alt=""
Step 03: Create container registry on ECR and Push docker image to ECR
- Go to AWS ECR in the AWS management console.
- Create a repository. I have selected the public repository and the repo name.
- Select all the operating systems and versions according to the OS of Fargate you would select. Finally, create the repository.
data:image/s3,"s3://crabby-images/23766/2376695af6a854391f6b73f8d2cf62e5f6d57bc2" alt=""
- Repository has been created successfully.
data:image/s3,"s3://crabby-images/73357/73357f7fb29726b840ee8d517151183d8cb90d88" alt=""
- Now go to instance and write a Dockerfile to build Docker image.
FROM node:12.2.0-alpine
WORKDIR app
COPY . .
RUN npm install
RUN npm run test
EXPOSE 8000
CMD ["node","app.js"]
data:image/s3,"s3://crabby-images/34738/34738524fa62c2415a46be9c83ac1c778da7b9e0" alt=""
- Now, we will run the given commands that will be given in the “View Push Command” on the EC2 instance.
data:image/s3,"s3://crabby-images/479ba/479ba480e05e3c2093b277af76034c4f710bdfda" alt=""
- Now Run first command to authenticate your docker client to your container registry.
data:image/s3,"s3://crabby-images/8f8a7/8f8a7e614c9d044a75ec68672d7ea64d61849b99" alt=""
- Build docker image with tag project-05
docker build -t <tag-name> .
`
data:image/s3,"s3://crabby-images/eab48/eab4809e96674b62b4e9aaecb1b46ca4fab6de61" alt=""
- Push docker image to ECR repository
docker push <repo url>:latest
`
data:image/s3,"s3://crabby-images/f6ff5/f6ff5acf905138b5d060bed26bb7903db7b0f5dc" alt=""
- After the image push, you can check the ECR for the image.
data:image/s3,"s3://crabby-images/0aa55/0aa55ca37694b646f76f0dece3da722b9e183a83" alt=""
Step 04:- Create a Cluster in ECS.
- Navigate to the ECS service in the AWS console.
- Create a cluster in ECS.
- Provide the Cluster name, VPC and subnet you want your application to be available on.
data:image/s3,"s3://crabby-images/4d377/4d37744e0fcbc2250db4e6cb1df16f43d8cad243" alt=""
- The cluster is now ready!!!
data:image/s3,"s3://crabby-images/95bfd/95bfd52ef4362236931d11d8a14a33b249d99ca9" alt=""
- We used to run docker run to create a container in the EC2 instance out of the docker image. That was nothing but a task. Therefore let’s create a task definition for our cluster.
data:image/s3,"s3://crabby-images/7cfd9/7cfd95119f76ae7a51a677db0f973dd281aa45d5" alt=""
- Now, we will configure a task definition here, by providing the Task Name, Container Name, and URL of the image that is in the Repository and clicking on “Create”.
data:image/s3,"s3://crabby-images/c5037/c5037d463930caffd89888f93783a97f08fa5375" alt=""
- Here, you can see that the task status is active.
data:image/s3,"s3://crabby-images/75fcd/75fcd8ed988bd4420b298a376814916e2090d5ae" alt=""
- Now, click on “Create service”.
data:image/s3,"s3://crabby-images/a0d52/a0d528fdb1c7146a9d474c58cbd70392144320c0" alt=""
- Choose the cluster. Select the launch type to be Fargate.
data:image/s3,"s3://crabby-images/c60d3/c60d31dad35b542ea35a826a5b35e4ed26111894" alt=""
- The task is now deployed to the cluster.
- Navigate to the ENI ID in the task.
- Go to the security group URL.
- Navigate to the Inbound rule in the security group and open the Port 8000 which is HTTP and select my IP to have access for myself.
- Copy the Public Ip of the Container with port 8000, and the site will be live.
data:image/s3,"s3://crabby-images/c40c5/c40c5582cfc54e453da564c043c7958ecef60a59" alt=""
⛔Note:-Don’t forget to Stop or Delete all clusters and services of ECS otherwise this will cost you unknowingly..⚠⚠
🔶That’s all about today’s task of DevOps journey
🔸Thankyou for reading 👍.
If you liked this story then click on 👏👏 do follow for more interesting and helpful stories.
More content at PlainEnglish.io. Sign up for our free weekly newsletter. Follow us on Twitter, LinkedIn, YouTube, and Discord. Interested in Growth Hacking? Check out Circuit.
— — — — — — — — #keepLearning_DevOpsCloud ♾️☁️ — — — — — —
data:image/s3,"s3://crabby-images/cbe9d/cbe9dfb018fe7966cd4b1cbd1e7bed665ee7bc68" alt="Hands-on DevOps Project 05"