We have a Object Detection Application that follows a microservice architecture, consisting of four separate containers that communicate using either DOCKER COMPOSE or KUBERNETES.
Following are the different components of our application:
The frontend/UI of our application, allowing us to enter images as input and receive the output.
Used to connect & perform I/O operations from the Telegram application.
Object Detection Model, the main component of our application that performs all the computation and calculations, providing us with the output.
Database to store all the input images along with the output from the YOLO5 Object Detection Model.
???
That would be the complete arhictecture for the application that would be automated using a CI/CD (Continous Integration & Continous Delivery) pipeline that would be created using - JENKINS.
Following steps would be followed in order to create a CI/CD pipeline using Jenkins:
- Get code from Github repository
- Build & Tag Docker images for microservices
- Login to ECR (Elastic Container Registry)
- Push images to ECR
- Write unit tests (Optional, but we'll do it anyways :) )
- Create Infrastructure in AWS, if needed (for 'dev' branch)
- Deploy the application on either EC2(Elastic Compute Cloud) or EKS(Elastic Kubernetes Service). In order to deploy on EKS we'll be using HELM, package manager for K8S applications.