Skip to content

Latest commit

 

History

History
194 lines (91 loc) · 16.9 KB

README.md

File metadata and controls

194 lines (91 loc) · 16.9 KB

The new home for this repository will be: https://github.com/aws-samples/serverless-cicd-ml-pipelines

AWS Serverless: Continuous ML Pipeline

Interested in making a contribution?

This is a framework for continuous machine learning pipeline automation on AWS. It provides an out-of-the-box integration of AWS serverless components and builds on top of the capabilities provided by services like AWS CodePipeline and the AWS Step Functions Data Science SDK. The framework is designed to be extensible and facilitate a low-code approach to ML pipeline automation.

The intended design of the system is as follows (note that this framework is still work in progress):

architecture

The solution can be automatically deployed into your account using CloudFormation. Quick-start instructions are provided below. The solution can be deployed and a working example can be launched with just a few steps.

What does it do?

The following diagram illustrates the conceptual architecture for this solution.

architecture

Operational and pipelining processes vary greatly across projects and organizations by design. The pipeline design provided out-of-the-box is meant to serve as a boiler-plate. This is not a turnkey solution for enterprises.

Some organizations will need to re-design the pipeline to meet their requirements. Enhancements such as multi-account support will be needed in some cases.

The out-of-the-box pipeline serves as a learning example--it should help a developer understand how to bring AWS's DevOps building blocks together for ML pipeline automation. It also provides a starting point for you to iterate on.

Trek10's Enterprise CI/CD Quick-start is a good example of something closer to an enterprise turn-key CI/CD solution (note: it doesn't provide ML pipelining out-of-the-box). However, the multi-account design makes it harder to deploy. One of the goals of this solution is to enable a working system in your AWS environment with a few simple steps.

Many of you will already have an existing CI/CD pipeline, and as described in the following section, you can replace the provided CI/CD backbone. Refer to the Advanced Concepts section below for more details on how to re-design, replace and configure the various components in this solution.

This project is open-source, and is open to contributions that add value to our community. Feel free to contact me if you have a valuable enhancement that you like to contribute to this project.


How does the provided pipeline work?

The provided pipeline consists of five main steps:


  1. Change detection: Changes to assets such as code, configurations and data can trigger the pipeline to run. Triggers include git pushes to the master branch in CodeCommit, or changes to data sets in your S3 bucket.

  2. Build Test and Stage Environment: The pipeline dynamically builds a test environment as defined by the provided CloudFormation templates. The environment consists of two parts:

    • The first is a machine learning pipeline built on AWS Step Functions. The purpose of the pipleine is to train, evaluate and deploy ML models. It can be reconfigured through the ML pipeline template and this configuration file

    • The second is the test environment consisting of your application and test suites. The environment can be configured through the following template. The provided template deploys a simple microservice consisting of a AWS Lambda function front by Amazon API Gateway. It communicates with the Amazon SageMaker hosted endpoint that is configured in the aforementationed configuration file. It also deploys a sample test suite that runs on Lambda.

  3. Run the ML Pipeline: The image below illustrates the the Step function workflow of the provided ML pipeline. The pipeline starts with a data prep step executed by AWS Glue. Next, a customer churn prediction model is trained using XGBoost and this job is tracked as by SageMaker Experiments for traceability. The train model is evaluated, and if it meets the performance criteria, the workflow proceeds to deploy the model as a SageMaker Hosted Endpoint. The worfklow completes successfully once the hosted endpoint reaches an in-service status. If the endpoint already exists, a model variant is deployed and the endpoint is updated.

  1. Test Automation: Once the ML pipeline delivers a healthy model server, we can run our test suites against our model server. The provided test is only meant to serve as an example. It simply invokes the endpoint and reports back the predicton results.

    CodePipeline also has integrations with 3rd-party QA automation software. You can follow the instructions below to modify the CI/CD backbone and integrate these solutions into your test process.

  2. Deploy to Production: Once the test completes, a manual approval process is required before the changes are deployed into production. Test results can be reported externally or as output variables in CodePipeline. Information gathered in SageMaker Experiments and CloudWatch also facilitate the audit.

    Once the reviewer approves the changes, the pipeline deploys them into production using this template. The provided template deploys a new copy of the simple microservice. This is optionally deployed into a VPC with a VPC endpoint. The API managed by API Gateway is promoted to production using a carnary deploy. Finally, a SageMaker Model Monitor is deployed and is scheduled to evaluate data drift issues on an hourly basis.

Common Design Patterns

The choosen design isn't the only way to integrate a ML pipeline into an existing CI/CD pipeline. Another common pattern is to have AWS Step Functions serve as the overlaying workflow manager and have both CodePipeline and the ML pipelining enclosed within a single Step Function workflow. One might favor this design for better consistency and perhaps a cleaner design.

However, there are trade-offs. The choosen design better decouples the CI/CD pipeline from the ML pipeline. This is ideal for the common case where a CI/CD pipeline already exists and you would like to minimize changes to your core application delivery system. This design augments the existing CI/CD pipeline with Step Function workflow. The integration between the CI/CD pipeline and Step Functions is simply a Lambda function that provides control flow logic. The coupling and dependencies are minimized between the systems. Thus, this integration strategy poses less risks and disruption.

Secondly, at the time of writing, Step Functions is best design to orchestrate systems running exclusively in the AWS cloud. The design pattern prescribed is more flexible. You could replace the CodePipeline backbone in this solution with an on-premise CI/CD solution. The other parts of the pipeline are decoupled and could run in the cloud as part of a hybrid cloud architecture.

Quick Start Instructions

Pre-requesites:

Step 1: Deploy the CodePipeline CI/CD pipeline back-bone

Click on the launch button. Provide a stack name and the rest of the fields can be left with the default values. The launch button defaults to us-west-2, but you can change the region from the console.

launch stack button

Step 2: Wait for template to reach the create complete status.

cicd

Step 3: Trigger your pipeline to run

If you're running on a Mac OS, you can simply download and run this shell script.

If not, git clone this repository and git push all the assets to the CodeCommit repository created in step 1. By default, the CodeCommit repository is called mlops-repo.

Specifically, the steps are:

  1. git clone https://github.com/dylan-tong-aws/aws-serverless-ml-pipeline.git ./tmp
  2. git clone ssh://git-codecommit.<Insert Your Selected AWS Region>.amazonaws.com/v1/repos/mlops-repo
  3. Copy the contents in the "tmp" directory to the "mlops-repo" directory.
  4. From within the mlops-repo directory:
    • git add -A
    • git commit -m "aws ml pipeline assets"
    • git push

You can monitor the pipeline progression from the CodePipeline and AWS Step Functions console. Enjoy!

FAQ

  1. How do I change the configurations such as the algorithm and hyperparameters used by the provided ML pipeline?

    The provided ML pipeline can be configured through the ml-pipeline-config.json file. The configuration file includes configurations to change the algorithm, hyperparameters, endpoint name, experiment tracking, ETL configurations, data source location and more.

    The data prep script can also be modified. The provided ML pipeline uses AWS Glue, so the script has to be written for Spark and the supported context.

  2. How do I modify or replace the workflow structure of the machine learning pipeline?

    The machine learning pipeline deployment is contained within the mlops-ml-pipeline.yaml template. There are two main components:

    • The Step Function definition metadata which describes the Step Function workflow for the pipeline. It leverages the Data Science SDK, which provides an integration with Amazon SageMaker. The logical resource id for the pipeline is in MLPipeline. You can modify the Step Function definition in that file. Once you commit these changes, the CI/CD backbone will dynamically re-create the new ML pipeline.
    • Control logic is executed through a Lambda function called "ml-pipeline-controller." In some cases, the Data Science SDK isn't sufficient and additional logic has to be implemented. The controller manages more advanced state transitions and serves as an integration point between CodePipeline and Step Functions. You may need to implement additional custom logic to support enhancements to the ML pipeline.
  3. How do I modify the application logic?

    The provided pipeline deploys a simple microservice. It consists of an API that takes features as input and responds with a prediction. The back-end logic is executed in Lambda and it's sole responsibility is to mediate communication between the SageMaker hosted model and the client. You can enhance the microservice by modifying the business logic. There're API definitions managed by API Gateway for both test and production environments. These environments are defined in mlops-test-env.yaml and mlops-deploy-prod.yaml.

    AppApiInTest and the AppApiInProd are the logical identifiers in these respective templates. The API definitions are defined in swagger 2.0 format.

  4. How do I modify and add test suites?

    The pipeline provides a sample test and it is up to your to extend and implement your relevant automated tests. The CI/CD pipeline runs a Lambda function called mlops-test-runner. You should modify this Lambda function so that it serves as a starting point to run your tests. For instance, you might choose to have this Lambda function kick-off a Step Function workflow that orchestrates the execution of your tests. Alternatively, this Lambda function might kick off a series of tests running as containerized workloads in Fargate. The design and implementation is left to you.

    CodePipeline also has integrations with 3rd-party QA automation software. You can follow the instructions below to modify the CI/CD backbone and integrate these solutions into your test process.

  5. How do I modify my test environment resources?

    The test environment resources are contained within mlops-test-env.yaml. The environment is built dynamically by the CI/CD backbone. You can modify this template as needed.

  6. How do I modify my production environment resources and deployment strategy?

    The production environment resources are contained within mlops-prod-deploy.yaml. The deployment process is executed through a CloudFormation stack update through the CI/CD backbone. You can modify this template as needed. For instance, the canary deploy and production stage settings can be changed through this template.

  7. How do I modify the model monitoring functionality?

    The provided pipeline deploys a SageMaker default monitor. You can create a custom monitor and modify the monitor image resource used by the MonitoringSchedule resource defined in mlops-prod-deploy.yaml.

  8. How do I modify or replace the CodePipeline CI/CD backbone?

    The CI/CD Pipeline backbone is defined in this template. You can modify the CodePipeline stages by modifying the proprities defined for the resource, CICDPipeline.

    If you want to replace CodePipeline as the CI/CD backbone, you could integrate your alternative CI/CD solution using the same or similar strategy employed in this example. Ultimately, your solution needs to be able to make API calls to AWS Lambda and CloudFormation to orchestrate the other parts of this pipeline. The provided assets and design could be re-used and serve as a reference.

  9. At what stage in a ML project lifecycle am I meant to use this solution?

    This solution was designed to productionize machine learning pipelines. It's meant to be used for production and is likely too heavyweight for use during development.

Refer to this blog post to learn more about the ML lifecycle.

Known Issues

  1. [6/2/2020] Network communication between Lambda and SageMaker VPC interface endpoint

    The provided template includes VPC support. However, at the time of writing, there is a network issue between AWS Lambda and the VPC interface endpoint that prevents communication between a Lambda function running in a VPC and a SageMaker hosted endpoint through a VPC interface endpoint. Consequently, communication between Lambda and the hosted endpoint needs to be public until this issue is fixed.

Acknowledgements

A sample data was packaged with this solution to simplify the Quick Start process. This data set was first mentioned in a book Discovering Knowledge in Data by Daniel T. Larose and is publicly available. It is attributed by the author to the University of California Irvine Repository of Machine Learning Datasets.