MLREL-02: Adopt a machine learning microservice strategy
Where appropriate, a complex business problem can be usefully decomposed into a series of machine learning models with a loosely coupled implementation. This can be accomplished by adopting a microservice instead of a monolithic architecture. This approach replaces one large resource with multiple small resources and can reduce the impact of a single failure on the overall workload. This strategy enables distributed development and improves scalability, enabling easier change management.
Implementation plan
- 
            Adopt a microservice strategy - Service-oriented architecture (SOA) is the practice of making software components reusable using service interfaces. Instead of building a monolithic application, where all functionality is contained in a single runtime, the application is instead broken into separate components. Microservices extend this by making components that are single-purpose and reusable. When building your architecture, divide components along business boundaries or logical domains. Adopt a philosophy that favors single-purpose applications that can be composed in different ways to deliver different end-user experiences. 
- 
            Use AWS services in developing microservices - Two popular approaches for developing microservices are using AWS Lambda and Docker containers with AWS Fargate . With AWS Lambda, you can run code for virtually any type of application or backend service with zero administration. You pay only for the compute time you consume, and there is no charge when your code is not running. A common approach to reduce operational efforts for deployment is using a container- based deployment. AWS Fargate is a container management service that allows you to run serverless containers so you don’t have to worry about provisioning, configuring, and scaling clusters of virtual machines to run containers. 
Documents
Blogs
- 
            Deploying Python Flask microservices to AWS using open-source tools 
- 
            Integrating machine learning models into your Java-based microservices 
- 
            Adopting machine learning in your microservices with DJL (Deep Java Library) and Spring Boot 
- 
            Building, deploying, and operating containerized applications with AWS Fargate