Chandika, 2018) 6 "The microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies. “ (Martin Fowler)
to quickly penetrate the market • No longer interested developing consolidated & managing end-to-end business functions. • To be more agility, speed of delivery, and scale to compete market. • Technology • Emergence of HTML5, CSS3, Client-side JavaScript framework, mobile platform & apps. • Revolutionized space of the database, NoSQL. • Infrastructure Management, PaaS, Container revolution & orchestration. Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 7
bees build a honeycomb by aligning hexagonal wax cells. They start small, using different materials to build the cells. Construction is based on what is available at the time of building. Repetitive cells form a pattern, and result in a strong fabric structure. Each cell in the honeycomb is independent, but also integrated with other cells. By adding new cells, the honeycomb grows organically to a big, solid structure. The content inside the cell is abstracted and is not visible outside. Damage to one cell does not damage other cells, and bees can reconstruct those cells without impacting the overall honeycomb. “ Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 9
and reduce boilerplate code. • Spring Config Server Externalize Configuration • Netflix Eureka Service Discovery/ Dynamic Service Registration, mid-tier load balancing & failover. • Netflix Zuul Service Proxy/ Gateway API. • Netflix Hystrix Circuit Breaker / Self Healing • Netflix Ribbon Inter Process Communication (remote procedure calls) library with built in load balancers. • Feign Declarative HTTP Client Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 14 And many more….
Discovery Service • Business Domain • To-do Service • Audit Trail Service • Integration Domain • Message Service • Front End • Vue.Js Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 18
• Swagger & Web UI • H2 Web Console • HATEOAS • WebTools • Project Starter • Web (http://start.spring.io) • IntelliJ IDEA • And many more… Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 22
• Developing distributed system can be complex (request & latency) • Deploying microservice can be complex (coordination). • Testing of application are harder. Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 25
concern (Security, Auth, Logging, etc). • Add more tech Integration (Elastic Search/ NoSQL). • Refactor to Event-driven/Message-driven Architecture. • Add CI/CD & Container base deployment to Cloud. • Develop small Market Place project. • And many more… Microservice Architecture with Spring Cloud (Maikel Chandika, 2018) 28