Skip to content

Latest commit

 

History

History
 
 

05-monitoring

5. Model Monitoring

5.1 Monitoring for ML-based services

Slides

5.2 Setting up the environment

5.3 Creating a prediction service and simulating traffic

5.4 Realtime monitoring walktrough (Prometheus, Evidently, Grafana)

5.5 Batch monitoring walktrough (Prefect, MongoDB, Evidently)

5.6 Homework

More information here: homework.md. Please also give us feedback for this week videos using this form

Notes

Did you take notes? Add them here:

Monitoring example

Prerequisites

You need following tools installed:

  • docker
  • docker-compose (included to Docker Desktop for Mac and Docker Desktop for Windows )

Preparation

Note: all actions expected to be executed in repo folder.

  • Create virtual environment and activate it (eg. python -m venv venv && source ./venv/bin/activate)
  • Install required packages pip install -r requirements.txt
  • Run python prepare.py for downloading datasets

Monitoring Example

Starting services

To start all required services, execute:

docker-compose up

It will start following services:

  • prometheus - TSDB for metrics
  • grafana - Visual tool for metrics
  • mongo - MongoDB, for storing raw data, predictions, targets and profile reports
  • evidently_service - Evindently RT-monitoring service (draft example)
  • prediction_service - main service, which makes predictions

Sending data

To start sending data to service, execute:

python send_data.py

This script will send every second single row from dataset to prediction service along with creating file target.csv with actual results (so it can be loaded after)

Batch Monitoring Example

After you stop sending data to service, you can run batch monitoring pipeline (using Prefect) by running script:

python prefect_example.py

This script will:

  • load target.csv to MongoDB
  • download dataset from MongoDB
  • Run Evidently Model Profile and Evidently Report on this data
  • Save Profile data back to MongoDB
  • Save Report to evidently_report_example.html

You can look at Prefect steps in Prefect Orion UI (to start it execute prefect orion start)