Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/chandru-21/mlops_project
An end-to-end MLOps pipeline(CI/CD/CT/CM) project for training, versioning, deploying, and monitoring machine learning models using FastAPI, Kubernetes, MLflow, DVC, Prometheus, and Grafana.
https://github.com/chandru-21/mlops_project
aws cicd data-science docker dvc evidentlyai fastapi github-actions grafana grafana-dashboard kubernetes machine-learning mlops mlops-community mlops-project mlops-template prometheus
Last synced: about 1 month ago
JSON representation
An end-to-end MLOps pipeline(CI/CD/CT/CM) project for training, versioning, deploying, and monitoring machine learning models using FastAPI, Kubernetes, MLflow, DVC, Prometheus, and Grafana.
- Host: GitHub
- URL: https://github.com/chandru-21/mlops_project
- Owner: Chandru-21
- Created: 2024-06-16T07:55:38.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-07-05T10:49:01.000Z (8 months ago)
- Last Synced: 2024-11-15T14:10:06.781Z (3 months ago)
- Topics: aws, cicd, data-science, docker, dvc, evidentlyai, fastapi, github-actions, grafana, grafana-dashboard, kubernetes, machine-learning, mlops, mlops-community, mlops-project, mlops-template, prometheus
- Language: Python
- Homepage:
- Size: 60.5 KB
- Stars: 9
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Machine Learning Opearations (MLOps)
## MLOps maturity level 4
## Overview :
This project implements a robust MLOps pipeline, facilitating the continuous integration, continuous deployment, and monitoring of machine learning models. The infrastructure leverages AWS, Kubernetes, and various open-source tools to ensure scalability, reproducibility, and maintainability.## Architecture :
data:image/s3,"s3://crabby-images/f46ca/f46caf729b54ba40c4354cf33e30417b5de75d65" alt="image"
## Key Features :
**Data Versioning** : DVC
**Continuous Integration(CI)** : Triggered through ‘main.yml’ , building the code (docker), tests the code(Pytest),pushes the docker image to AWS ECR.
**Experiment Tracking / Model Versioning** : MLflow
**Continuous Deployment(CD)** : Deploys FastAPI in AWS EKS(kubernetes cluster) for real-time and batch predictions.
**Continuous Monitoring(CM)** : Integrating the ‘/metrics’ method of FastAPI in Prometheus and visualizes endpoints in Grafana.
**Continuous Training(CT)** : Triggers code execution through GitHub Actions when new data is pushed to the remote DVC location and committed to Git.
**Drift Monitoring** : Uses a Streamlit app to monitor data drift, target drift, and performs data quality checks.
## Data Monitoring :
**Data Drift Monitoring** :
data:image/s3,"s3://crabby-images/f8026/f802682cd2e1e5c14457870716f5fcf37f0edeb1" alt="image"
**Data Quality checks** :
data:image/s3,"s3://crabby-images/1a758/1a758d10f36662ccae7fe2b899b8de1cefdcd14a" alt="image"
## Continuous Monitoring(CM)
**Exposing "/metrics" on FastAPI to be connected to Prometheus** :
data:image/s3,"s3://crabby-images/22b8c/22b8c0277c4a933f7661d295b99a213581a5de51" alt="fastapi"
**FastAPI integrated in to Prometheus** :
data:image/s3,"s3://crabby-images/26006/26006c4ae1a2075577eb2c0ae9945cfd322a4cb1" alt="fastapi_prometheus"
**Integrating Prometheus in to Grafana for Visualization** :
Monitoring FastAPI methods on Grafana,
data:image/s3,"s3://crabby-images/84e14/84e14d45b35002464787468d08aec2353af3336a" alt="fastapi_continuous_monitoring"
**Monitoring the resources of the Kubernetes cluster on Grafana** :
data:image/s3,"s3://crabby-images/44dd8/44dd848c9cbd573b10ccf0c4aa0c35c60bffd448" alt="grafana_monitoring_containers_dashboard"