Full Stack Development with JHipster
Build full stack applications and microservices with Spring Boot and modern JavaScript frameworks, 2nd Edition
Deepu K Sasidharan, Sendil Kumar N
- 428 pages
- English
- ePUB (mobile friendly)
- Available on iOS & Android
Full Stack Development with JHipster
Build full stack applications and microservices with Spring Boot and modern JavaScript frameworks, 2nd Edition
Deepu K Sasidharan, Sendil Kumar N
About This Book
Written by the core development team of JHipster and fully updated for JHipster 6, Java 11, and Spring Boot 2.1, this book will show you how to build modern web applications with real-world examples and best practices
Key Features
- Build full stack applications with modern JavaScript frameworks such as Angular, React, and Vue.js
- Explore the JHipster microservices stack, which includes Spring Cloud, Netflix OSS, and the Elastic Stack
- Learn advanced local and cloud deployment strategies using Docker and Kubernetes
Book Description
JHipster is an open source development platform that allows you to easily create web apps and microservices from scratch without spending time on wiring and integrating different technologies. Updated to include JHipster 6, Java 11, Spring Boot 2.1, Vue.js, and Istio, this second edition of Full Stack Development with JHipster will help you build full stack applications and microservices seamlessly.
You'll start by understanding JHipster and its associated tools, along with the essentials of full stack development, before building a monolithic web app. You'll then learn the JHipster Domain Language (JDL) with entity modeling using JDL-Studio. With this book, you'll create production-ready web apps using Spring Boot, Spring Framework, Angular, and Bootstrap, and run tests and set up continuous integration pipelines with Jenkins. As you advance, you'll learn how to convert your monoliths to microservices and how to package your application for production with various deployment options, including Heroku and Google Cloud. You'll also learn about Docker and Kubernetes, along with an introduction to the Istio service mesh. Finally, you'll build your client-side with React and Vue.js and discover JHipster's best practices.
By the end of the book, you'll be able to leverage the best tools available to build modern web apps.
What you will learn
- Create full stack apps from scratch using the latest features of JHipster 6 and Spring Boot 2.1
- Build business logic by creating and developing entity models using JDL
- Understand how to convert a monolithic architecture into a full-fledged microservices architecture
- Build and package your apps for production using Docker
- Deploy your application to Google Cloud with Kubernetes
- Create continuous integration/continuous delivery pipelines with Jenkins
- Create applications using Angular, React, and Vue.js client-side frameworks
Who this book is for
This book is for full stack developers who want to build web applications and microservices speedily without writing a lot of boilerplate code. If you're a backend developer looking to learn full stack development with JavaScript frameworks and libraries such as Angular, React, and Vue.js, you'll find this book useful. Experience in building Java web applications is required. Some exposure to the Spring Framework would be beneficial but not necessary to get the most out of this book.
Frequently asked questions
Information
Section 1: Getting Started with the JHipster Platform
- Chapter 1, Introduction to Modern Web Application Development
- Chapter 2, Getting Started with JHipster
Introduction to Modern Web Application Development
- Modern full stack web development
- Web architecture patterns
- Choosing the right pattern
Modern full stack web development
- You would start by designing the architecture for the feature. You would decide on the plugins and frameworks to use, patterns to follow, and so on.
- You will be modeling the domain model for the feature depending on the database technology used.
- Then, you would create server-side code and database queries to persist and fetch data from the database.
- Once the data is ready, you would implement server-side code for any business logic.
- Then, you would implement an API that can be used to provide data for the presentation over an HTTP connection.
- You would write integration tests for the API.
- Since the backend is ready, you would start writing frontend code in JavaScript or similar technology.
- You would write client-side services to fetch data from the backend API.
- You would write client-side components to display the data on a web page.
- You would build the page and style it as per the design provided.
- You would write some automated end-to-end tests for the web page.
- You are not done yet. Once you have tested whether everything works locally, you would create pull requests or check the code into the version control system used.
- You would wait for the continuous integration process to verify everything and fix anything that is broken.
- Once everything is green and the code is accepted, you would typically start the deployment of this feature to a staging or acceptance environment, either on-premises or to a cloud provider using technologies like Docker and Kubernetes. If you choose the latter, you would be expected to be familiar with the cloud technologies used as well. You would also be upgrading the database schema as necessary and writing migration scripts when required.
- Once the feature is accepted, you might be responsible for deploying it into the production environment in a similar way, troubleshooting issues where necessary. In some teams, you might swap the steps with other team members so that you would be deploying a feature developed by your coworker while they deploy yours.
- You might also be responsible, along with your coworkers, for making sure that the production environment is up and running, including the database, virtual machines, and so on.
- Client-side development is not just about writing plain HTML and JavaScript anymore. It is becoming as complex as server-side development, with build tools, transpilers, frameworks, and patterns.
- There is a new framework almost every week in the JavaScript world, and if you are coming from a Java background, it could be very overwhelming for you.
- Container technologies such as Docker revolutionized the software industry, but they also introduced a lot of new stuff to learn and keep track of, such as orchestration tools and container management tools.
- Cloud services are growing day by day. To stay on track, you would have to familiarize yourself with their APIs and related orchestration tools.
- Java server-side technologies have also undergone a major shift in recent times with the introduction of JVM languages, such as Scala, Groovy, and Kotlin, forcing you to keep yourself up to date with them. On the other side, server-side frameworks are becoming more feature-rich, and therefore more complex.
Web architecture patterns
Monolithic web architecture
- It can support different clients, such as desktop/mobile browsers and native desktop/mobile applications.
- It can expose APIs for third-party consumption.
- It can integrate with other applications over REST/SOAP web services or message queues.
- It can handle HTTP requests, execute business logic, access databases, and exchange data with other systems.
- It can run on web application containers, such as Tomcat and JBoss.
- It can be scaled vertically by increasing the power of the machines it runs on or scaled horizontally by adding additional instances behind load balancers.
SOAP (short for Simple Object Access Prot...