Introduction
Intro to MLopsâš‘
MLOps, or Machine Learning Operations, is a discipline that merges the # MLOps: Unifying Machine Learning System Development and Operation
MLOps, or Machine Learning Operations, is a discipline that merges the development (Dev) and operation (Ops) of machine learning (ML) systems. As data science and ML continue to become key capabilities for solving complex real-world problems, the practice of MLOps is gaining traction. MLOps aims to promote automation and monitoring throughout the construction of ML systems, including integration, testing, release, deployment, and infrastructure management.
MLOps is More than Just ML Codeâš‘
The complexity of real-world ML systems goes beyond the ML code. The required elements surrounding the ML code comprise a vast and intricate system that includes configuration, automation, data collection, data verification, testing and debugging, resource management, model analysis, process and metadata management, serving infrastructure, and monitoring. In other words, only a small fraction of an ML system is composed of the ML code itself.
MLOps: A Marriage of DevOps and Machine Learningâš‘
Just as DevOps principles have proved beneficial in the development and operation of large-scale software systems, these principles are applicable to ML systems as well. However, ML systems have distinct characteristics:
- Team skills: An ML project typically involves data scientists or ML researchers who might not be experienced software engineers capable of building production-class services.
- Development: ML is experimental in nature. Challenges arise in tracking what worked and what didn't, and maintaining reproducibility while maximizing code reusability.
- Testing: Testing an ML system is more complex than testing other software systems. It requires data validation, trained model quality evaluation, and model validation.
- Deployment: Deployment in ML systems often entails deploying a multi-step pipeline to automatically retrain and deploy models.
- Production: ML models can experience performance degradation due to constantly evolving data profiles, necessitating the tracking of summary statistics of data and monitoring of the online performance of models.
Developing ML Models: Steps to Successâš‘
Although the precise steps may vary depending on the specific ML project, a general process can be outlined for developing ML models:
- Understanding the problem: This involves defining the business problem, identifying the ML task, and preparing the initial data.
- Data preparation: This step includes gathering, cleaning, and transforming data for the ML model.
- Model building: This includes selecting the model, training it, and then evaluating its performance.
- Model deployment: This involves deploying the model into a production environment.
- Monitoring and maintenance: This step involves monitoring the performance of the model over time, retraining it as necessary, and performing model updates.
MLops Hierarchy of needsâš‘
To reach the Mlops level you have to achieve a few steps before you can reach the next level. You cannot, for example, have DataOps without first implementing devops.
You need to achieve one step of the bottom
MLOps Maturity Levelsâš‘
there are several different phases of going from a crude working where you can barely get things into production and things are error-prone and manual all the way to a very sophisticated system that has really end-to-end automation and uses the next-generation features.
- Initial step: Experimentation. Establish the experimentation environment.
- Repeatable: standardize your code, your repos, make sure that there's maybe a platform that you're using that can actually deploy the solution.
- Reliable: Test, monitoring, data drift, model versions.
- Scalable: You're able to templatize and productionize a lot of different ML solutions, not just one, but actually have a scalable system that you can repeat over and over again
Level | Description | Highlights | Technology |
---|---|---|---|
0 | No MLOps |
| |
1 | DevOps but no MLOps |
|
|
2 | Automated Training |
|
|
3 | Automated Model Deployment |
|
|
4 | Full MLOps Automated Operations |
|
|
Level 0: No MLOpsâš‘
-
People: Data scientists, data engineers, and software engineers are siloed and not in regular communications.
-
Model Creation: Data is gathered manually, compute is likely not managed, experiments aren't predictably tracked, and the end result may be a single model file manually handed off.
- Model Release: The release process is manual, and the scoring script may be manually created well after experiments without version control.
- Application Integration: Heavily reliant on data scientist expertise to implement and manual releases each time.
Level 1: DevOps no MLOpsâš‘
-
People: Same as Level 0.
-
Model Creation: Data pipeline gathers data automatically, but compute may not be managed, and experiments aren't predictably tracked.
- Model Release: Still a manual process, but the scoring script is likely version controlled and is handed off to software engineers.
- Application Integration: Basic integration tests exist, but still heavily reliant on data scientist expertise. However, releases are automated and application code has unit tests.
Level 2: Automated Trainingâš‘
-
People: Data scientists work directly with data engineers to convert experimentation code into repeatable scripts/jobs, while software engineers remain siloed.
-
Model Creation: Data pipeline gathers data automatically, compute is managed, experiment results are tracked, and both training code and resulting models are version controlled.
- Model Release: Manual release, but the scoring script is version controlled with tests and the release is managed by the software engineering team.
- Application Integration: Same as Level 1.
Level 3: Automated Model Deploymentâš‘
-
People: Data scientists and data engineers work together and also with software engineers to manage inputs/outputs and automate model integration into application code.
-
Model Creation: Same as Level 2.
- Model Release: Release is automatic and managed by a continuous delivery (CI/CD) pipeline.
- Application Integration: Unit and integration tests exist for each model release, and the process is less reliant on data scientist expertise. Application code has unit/integration tests..
Level 4: Full MLOps Automated Retrainingâš‘
-
People: All roles work together, with software engineers implementing post-deployment metrics gathering.
-
Model Creation: Similar to Level 3, but retraining is triggered automatically based on production metrics.
- Model Release: Same as Level 3.
Referencesâš‘
Created: 2024-10-23