Book Image

Building Microservices with Micronaut®

By : Nirmal Singh, Zack Dawood
Book Image

Building Microservices with Micronaut®

By: Nirmal Singh, Zack Dawood

Overview of this book

The open source Micronaut® framework is a JVM-based toolkit designed to create microservices quickly and easily. This book will help full-stack and Java developers build modular, high-performing, and reactive microservice-based apps using the Micronaut framework. You'll start by building microservices and learning about the core components, such as ahead-of-time compilation, reflection-less dependency injection, and reactive baked-in HTTP clients and servers. Next, you will work on a real-time microservice application and learn how to integrate Micronaut projects with different kinds of relational and non-relational databases. You'll also learn how to employ different security mechanisms to safeguard your microservices and integrate microservices using event-driven architecture in the Apache Kafka ecosystem. As you advance, you'll get to grips with automated testing and popular testing tools. The book will help you understand how you can easily handle microservice concerns in Micronaut projects, such as service discovery, API documentation, distributed configuration management, fallbacks, and circuit breakers. Finally, you'll explore the deployment and maintenance aspects of microservices and get up to speed with the Internet of Things (IoT) using the Framework. By the end of this book, you'll be able to build, test, deploy, and maintain your own microservice apps using the framework.
Table of Contents (20 chapters)
1
Section 1: Core Concepts and Basics
3
Section 2: Microservices Development
8
Section 3: Microservices Testing
10
Section 4: Microservices Deployment
13
Section 5: Microservices Maintenance
15
Section 6: IoT with Micronaut and Closure

Chapter 11

  1. The following are a few factors to consider when architecting microservices are the following:
    • Does your team know about microservices?
    • Is your business mature enough to adopt microservices?
    • Do you have an Agile DevOps practice and infrastructure?
    • Do you have a scalable on-premise or cloud infrastructure?
    • Do you have support to use modern tools and technology?
    • Is your database ready to be decentralized?
    • Do you have support from all the stakeholders?

      We discussed this in the Architecting enterprise microservices section.

  2. These are some design patterns:
    • Decomposition by business capability
    • Decomposition by domain/sub-domains
    • The API Gateway pattern
    • The chained microservices pattern
    • Database per service
    • The command query responsibility segregation pattern
    • The service discovery pattern
    • The circuit breaker pattern
    • The log aggregation pattern

      We discussed this in the Design section.

  3. The following are a few factors to consider during the design phase of microservices:
    • Design...