In this project, I applied the skills which I have acquired in this course to operationalize a Machine Learning Microservice API. This project tests my ability to operationalize a Python Flask App in a provided file, app.py that serves out predictions (inference) about housing prices through API calls.
You are given a pre-trained,
sklearn
model that has been trained to predict housing prices in Boston according to several features, such as average rooms in a home and data about highway access, teacher-to-pupil ratios, and so on. You can read more about the data, which was initially taken from Kaggle, on the data source site. This project tests your ability to operationalize a Python flask app—in a provided file,app.py
—that serves out predictions (inference) about housing prices through API calls. This project could be extended to any pre-trained machine learning model, such as those for image recognition and data labeling.
This project aim is to operationalize this working, machine learning microservice using kubernetes, which is an open-source system for automating the management of containerized applications. In this project you will:
- Test your project code using linting
- Complete a Dockerfile to containerize this application
- Deploy your containerized application using Docker and make a prediction
- Improve the log statements in the source code for this application
- Configure Kubernetes and create a Kubernetes cluster
- Deploy a container using Kubernetes and make a prediction
- Upload a complete Github repo with CircleCI to indicate that your code has been tested
You can find a detailed project rubric, here.
The final implementation of the project will showcase your abilities to operationalize production microservices.
- Create a virtualenv with Python 3.7 and activate it. Refer to this link for help on specifying the Python version in the virtualenv.
python3 -m pip install --user virtualenv
# You should have Python 3.7 available in your host.
# Check the Python path using `which python3`
# Use a command similar to this one:
python3 -m virtualenv --python=<path-to-Python3.7> .devops
source .devops/bin/activate
- Run
make install
to install the necessary dependencies - Run
make lint
to run linting tests on bothDockerfile
andapp.py
or runmake all
to both install dependencies and run linting
- Standalone:
python app.py
- Run in Docker:
./run_docker.sh
- Run in Kubernetes:
./run_kubernetes.sh
-
First ensure the app is running in one terminal using either of the above methods.
-
Run
./make_prediction.sh
in a separate terminal window
- Setup and Configure Docker locally
- Install docker on your system. Follow this link instrauctions on installation
- Run the app in docker(Dockerfile):
./run_docker.sh
- Check if the image is created:
docker images
- make pridictions:
./make_prediction.sh
- uplaod docker image to docker hub:
./upload_docker.sh
- Save Output logs to
docker_out.txt
file
- Setup and Configure Kubernetes locally
- Install kubernetes. If you installed docker desktop it comes with kubernetes you don't need to do another installation
- Install minikube. Follow instructions here for installation and setup
- Start minickube:
minikube start
- deploy with kubernetes(image uploaded dockerhub):
./run_kubernetes.sh
- make predictions:
./make_prediction.sh
- Run via kubectl
- Save Output logs to
kubernetes.out.txt
file
app.py
: Contains code that run the prediction modelDockerfile
: Contains instructions to contenarize the app.docker_out.txt
: Contains sample output after making predictions with dockerised appkubernetes_out.txt
: Contains sample output for predictions of the app deployed with kubernetesMakefile
: Defines a set of instructions to run usingmake
. two of the instructions used are:lint
andinstall
make_prediction.sh
: This file queries the model with some input data to make predicionsrequirements.txt
: includes project dependenciesrun_docker.sh
: script that runs the dockerised apprun_kubernetes.sh
: script that setups and runs the app with kubernetesuplaod_docker.sh
: script that uplaods local app docker image to docker hub