Book Image

Designing Hexagonal Architecture with Java - Second Edition

By : Davi Vieira
Book Image

Designing Hexagonal Architecture with Java - Second Edition

By: Davi Vieira

Overview of this book

We live in a fast-evolving world with new technologies emerging every day, where enterprises are constantly changing in an unending quest to be more profitable. So, the question arises — how to develop software capable of handling a high level of unpredictability. With this question in mind, this book explores how the hexagonal architecture can help build robust, change-tolerable, maintainable, and cloud-native applications that can meet the needs of enterprises seeking to increase their profits while dealing with uncertainties. This book starts by uncovering the secrets of the hexagonal architecture’s building blocks, such as entities, use cases, ports, and adapters. You’ll learn how to assemble business code in the domain hexagon, create features with ports and use cases in the application hexagon, and make your software compatible with different technologies by employing adapters in the framework hexagon. In this new edition, you’ll learn about the differences between a hexagonal and layered architecture and how to apply SOLID principles while developing a hexagonal system based on a real-world scenario. Finally, you’ll get to grips with using Quarkus to turn your hexagonal application into a cloud-native system. By the end of this book, you’ll be able to develop robust, flexible, and maintainable systems that will stand the test of time.
Table of Contents (24 chapters)
1
Part 1: Architecture Fundamentals
7
Part 2: Using Hexagons to Create a Solid Foundation
12
Part 3: Becoming Cloud-Native
18
Part 4: Hexagonal Architecture and Beyond

Deploying on minikube

minikube is a Kubernetes cluster that was made for development purposes. It allows us to create and destroy clusters with ease. Because of its simplicity, we’ll use minikube to deploy our hexagonal system by following these steps (I recommend following the instructions at https://minikube.sigs.k8s.io/docs/start/ to install minikube on your machine):

  1. Once you have installed minikube, you can start your cluster by issuing the following command:
    $ minikube start
    :) minikube v1.4.0 on Fedora 30
       Creating virtualbox VM (CPUs=2, Memory=2000MB, Disk=20000MB) ...
       Preparing Kubernetes v1.16.0 on Docker 18.09.9 ...
       Pulling images ...
       Launching Kubernetes ...
       Waiting for: apiserver proxy etcd scheduler controller dns
       Done! kubectl is now configured to use "minikube"

    The default cluster configuration consumes 2 CPUs, 2 GB of RAM, and 20 GB of disk...