ebook img

Software Architecture with Spring 5.0: Design and architect highly scalable, robust, and high-performance Java applications PDF

362 Pages·2018·22.292 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Software Architecture with Spring 5.0: Design and architect highly scalable, robust, and high-performance Java applications

Software Architecture with Spring 5.0 Design and architect highly scalable, robust, and high-performance Java applications René Enríquez Alberto Salazar BIRMINGHAM - MUMBAI Software Architecture with Spring 5.0 Copyright © 2018 Packt Publishing All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews. Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the authors, nor Packt Publishing or its dealers and distributors, will be held liable for any damages caused or alleged to have been caused directly or indirectly by this book. Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information. Commissioning Editor: Richa Tripathi Acquisition Editor: Sandeep Mishra Content Development Editor: Anugraha Arunagiri Technical Editor: Subhalaxmi Nadar Copy Editor: Safis Editing Project Coordinator: Ulhas Kambali Proofreader: Safis Editing Indexer: Aishwarya Gangawane Graphics: Tom Scaria Production Coordinator: Shraddha Falebhai First published: August 2018 Production reference: 1310818 Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK. ISBN 978-1-78899-299-2 www.packtpub.com mapt.io Mapt is an online digital library that gives you full access to over 5,000 books and videos, as well as industry leading tools to help you plan your personal development and advance your career. For more information, please visit our website. Why subscribe? Spend less time learning and more time coding with practical eBooks and Videos from over 4,000 industry professionals Improve your learning with Skill Plans built especially for you Get a free eBook or video every month Mapt is fully searchable Copy and paste, print, and bookmark content PacktPub.com Did you know that Packt offers eBook versions of every book published, with PDF and ePub files available? You can upgrade to the eBook version at www.PacktPub.com and as a print book customer, you are entitled to a discount on the eBook copy. Get in touch with us at [email protected] for more details. At www.PacktPub.com, you can also read a collection of free technical articles, sign up for a range of free newsletters, and receive exclusive discounts and offers on Packt books and eBooks. Contributors About the authors René Enríquez works as technical leader in a multinational company headquartered in Silicon Valley. He worked on different projects using Java Enterprise Edition and Spring Framework. He currently works with different Spring projects to maintain legacy code and write microservices applying best practices to deliver products using Agile techniques with a strong focus on testing at different levels. During the last years, he worked as a software consultant for private and government companies and as an instructor of courses to develop enterprise and mobile applications. He was also a speaker at the ScrumDay and JavaDay conferences in Quito-Ecuador. Alberto Salazar is an entrepeneur, passionate Java consultant, JUG leader, Auth0 ambassador and founder of the Java User Group of Ecuador, an associate member of the Java community process and a Java evangelist/trainer. He founded a consulting company in Latin America 10 years ago, where he creates and offers technical solutions based on Java. He has been working for 2 decades creating higly scalable and transactional systems. He is a regular speaker at multiple Java conferences and meetings. He recently organized a Java Conference in Ecuador with Java Champions and co-organized a Java Hackdays event in Spanish that brought together 11 different cities from around the world and 9 Spanish- speaking countries. About the reviewer Yogendra Sharma is a developer with experience in the architecture, design, and development of scalable and distributed applications. He was awarded a bachelor's degree from Rajasthan Technical University in computer science with a core interest in microservices and Spring. He also has hands-on experience in technologies such as AWS Cloud, Python, J2EE, NodeJS, Angular, MongoDB, and Docker. He is currently working as an IoT and cloud architect at Intelizign Engineering Services. He constantly explores technical novelties, and is open-minded and eager to learn about new technologies and frameworks. He has also technically reviewed books and video courses for Packt. Roland Alden has been the founder as well as co-founder of three technology startups and has decades of experience managing software engineering teams distributed around the world (Armenia, China, India, Micronesia, Nigeria, Pakistan, UAE, Ukraine, and Zambia). His background includes large companies (Data General and AT&T) and venture capital backed startups (Forethought, Go, and Eo). Currently, he works at ioet Inc., a software outsourcing firm based in Silicon Valley and Ecuador. He is a co-author of the Working with Computers and Working with Microsoft Office series of textbooks published by Houghton Mifflin. Packt is searching for authors like you If you're interested in becoming an author for Packt, please visit authors.packtpub.com and apply today. We have worked with thousands of developers and tech professionals, just like you, to help them share their insight with the global tech community. You can make a general application, apply for a specific hot topic that we are recruiting an author for, or submit your own idea. Table of Contents Preface 1 Chapter 1: Software Architecture Today 7 Defining software architecture 8 I know my land 9 I want to stay ahead 9 Predicting the future 10 Architecture and architects 11 Software architecture principles 13 Components 13 Low coupling 14 High cohesion 17 SOLID principles 18 The single responsibility principle (SRP) 18 The Open–Closed Principle (OCP) 19 The Liskov substitution principle 20 The interface segregation principle (ISP) 21 The dependency inversion (DI) principle 23 Conway's law 23 Choosing the right technology for you 25 New trends 27 Summary 28 Chapter 2: Software Architecture Dimensions 29 Dimensions 30 The business dimension 30 Managing user requirements 31 Identifying and tracking business metrics 32 The data dimension 32 The technical dimension 35 The operations dimension 37 How to deploy an application 37 How interaction occurs among your components 37 Dealing with infrastructure 37 Understanding the infrastructure 38 Versioning 38 Testing 39 Cloud versus on-premise 39 Deploying your application 40 The C4 model 41 Context diagram 42 Table of Contents Container diagram 42 Components diagram 43 Class diagram 43 Summary 44 Chapter 3: Spring Projects 45 Why Spring appeared 46 Spring projects 46 Spring Initializr 47 Spring Boot in a Nutshell 48 Servlet container integration 48 Autoconfiguration 48 Dependency management 48 mvnw and mvnw.cmd 49 pom.xml 49 DemoApplication.java 50 The application.properties file 51 DemoApplicationTests.java 51 Avoiding redeployment with developer tools 51 Spring Data 52 Supporting EIPs with Spring Integration 53 Spring Batch 55 The read step 55 The process step 56 The write step 56 Securing applications with Spring Security 56 Embracing (Spring) HATEOAS 58 Spring Cloud and the microservices world 59 Configuration server 59 Service registry 60 Edge services 60 Microproxy 61 API gateway 61 Circuit breaker 61 Reactive and Spring 62 Publisher 62 Subscriber 62 Subscription 63 Processor 63 Project reactor 63 Mono 64 Flux 65 Back pressure 66 Reactive Spring Data 67 Reactive REST services 68 Summary 69 Chapter 4: Client-Server Architectures 70 Understanding client-server architectures 71 [ ii ] Table of Contents Server 71 Scaling 72 Request 74 Client 74 Network 75 Where to apply client-server architectures 75 Implementing client-server architectures with Spring 77 The server 77 SOAP web services 78 RESTful web services 78 CORBA 79 Sockets 79 AMQP 79 Implementing the server 82 Banking-domain 82 Banking-api 83 Boundaries 84 Domain 85 Persistence 85 Service 85 Monitoring the server 85 Testing 87 Banking-client 89 Authentication endpoint client 90 Account balance endpoint client 91 The clients 91 JavaFX client 92 Android client 93 Thin client 95 Summary 96 Chapter 5: Model-View-Controller Architectures 97 MVC 98 The Model (M) 98 The View (V) 99 The Controller (C) 99 Benefits of using MVC 101 Common pitfalls 102 Implementing applications using MVC 104 Spring MVC 104 Testing 107 Test coverage 110 UI frameworks 113 Thymeleaf 114 Securing an MVC application 118 Basic authentication 119 Implementing basic authentication 121 Summary 124 [ iii ] Table of Contents Chapter 6: Event-Driven Architectures 125 Underlying concepts and key aspects 125 Command 126 Event 126 Patterns of event-driven architectures 128 Event notification 128 Event-carried state transfer 134 Improving application performance 135 Reducing the load on the source application 135 Increasing the availability of the system 136 Event sourcing 138 CQRS 148 Complex domain models 149 Distinct paths to query and persist information 150 Independent scaling 152 Summary 153 Chapter 7: Pipe-and-Filter Architectures 154 Introducing Pipe-and-Filter concepts 154 Filters 155 Pipes 156 Boarding Pipe-and-Filter architectures 156 Use cases for Pipe-and-Filter architecture 157 Spring Batch 158 Implementing pipes with Spring Batch 165 Summary 177 Chapter 8: Microservices 178 Principles of microservices 179 Size 179 Autonomous 179 Working well together 180 Advantages 180 Alignment to the single responsibility principle 181 Continuous releases 181 Independent scalability 181 Increased adoption of new technologies 182 Drawbacks 183 Too many options 183 Slow at the beginning 183 Monitoring 183 Transactions and eventual consistency 184 Modeling microservices 184 Speeding up 186 Accelerating the development process 186 Embracing tests 187 Going to production 188 [ iv ]

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.