How long did it take for you to roll out an MVP project that validated that awesome idea you just had? Or that freelance project you've committed to delivering with a tight deadline? Or even that side project you wanted to do but weren’t really sure how to kick off? With JHipster you will take no more than 20 minutes to create a simple microservice to validade your idea and solve your problems.Before, you probably had to worry about how your application would connect to the database, how to setup a database connection pool to handle many users, how to secure your application and manage the users, and how to deploy it either on an on-premise infrastructure or on a cloud environment. I can guarantee that these are just few elementary questions you will need to solve due to the inherent distributed nature of Microservice Architecture: scaling your Microservices, discovering and communicating to others, centralizing distributed logs, and monitoring all Microservices in a single dashboard.
I don't know about you, but when I worked on freelance projects, it used to take me quite a long time to progress from a greenfield application to effectively developing what really mattered: business logic. It made me wonder whether there were solutions out there that could do all the heavy-lifting for me, allowing me to skip all these time-consuming efforts and letting me put all my focus on developing my business. Well, I found an awesome tool that could do just that for me.JHipster is an open-source project that can handle all those previous concerns and many others. JHipster was originally concepted as bootstrap tool to generate monolithic applications using AngularJS as frontend (learn about the evolution of AgularJS) and Spring Boot as backend (if you are not a Sping Boot person learn about another option to build server-side applications with Java EE) , with its own custom interfaces in the middle of them to seamlessly integrate both technologies. The tool has a sweet pick-and-choose option to generate applications. For example, JHipster will ask you how you want to secure your new application, either using the classical HTTP Session Authentication or a token-based authentication with OAuth2 or JWT. You even have the option of using a social login with Twitter, Facebook, or Google authentication. JHipster is largely embraced by the community and its number of options offered has dramatically increased. Nowadays you can even develop your own module, which is a plugin you can integrate within any kind of framework and share on JHipster's marketplace
Besides monolithic applications, JHipster can generate modern applications based on Microservice Architecture. This architecture is mainly composed of three applications:
Take a look at the depicted architecture:
Learn more about refactoring monoliths to a Microservice architeture in our whitepaper "Microservices Architeture as a Large-Scale Refactoring Tool"
As this blog post title suggests, I propose we build a Microservice in the short span of 20 minutes as well as browse through some of its functionalities. Assuming that your environment already has Java8, NodeJS, and Docker installed, you should be able to create your Microservice in about 20 minutes. To give a bit of a background story, let's assume we are professional traders and we need to build a Microservice that will manage our book of transactions. There should be a simple CRUD operation with some required fields. We'll build a Microservice to handle all backend activities and a gateway to handle our Microservice entrances. But here’s the thing: I won't show you detailed step-by-step instructions on how to use the tool. Instead, I will point you to JHipster's awesome documentation that is so extensive that you won't have trouble walking through it by yourself. So, are you ready? I am. Let's go!
It's time to roll up our sleeves and to check out all the cool things JHipster can do for us. For this tutorial, make sure you have both Docker and Docker Compose installed. If you’re not familiar with Docker, check out this Docker post. Firstly, create a root directory for the project:
mkdir jhipster-microservice-example
cd jhipster-microservice-example
Start the JHipster Generator container to generate the applications:
docker container run --name jhipster_generator -v $(pwd):/home/jhipster/app -v ~/.m2:/home/jhipster/.m2 -p 8080:8080 -p 9000:9000 -p 3001:3001 -it --rm jhipster/jhipster bash
Our first generated application will be the Microservice. In order to do that, create a folder and run the JHipster generator command inside it:
mkdir orderbook
cd orderbook/
jhipster
Choose the following options for a Microservice:
Type of application: Microservice applicationJHipster will generate a bunch of files, including .yo-rc.json, which contains all of JHipster's metadata for the generated application. Now, it's time to generate our first entity. Let's create the Position entity by running JHipster's entity generator command with the following options:
jhipster entity position
This is what you should see for the first field:
Repeat the steps for the other fields. In the end, you will get the following:
Field: asset (String) requiredNote: You can safely override all conflicts caused by generated files.
The next step is to generate the gateway application, so that we can perform CRUD operations over the new entity. Go back to the project root directory and create a new folder for the gateway, enter it into the subfolder, and run the JHipster generator command again:
cd ../Type of application: Microservice gateway
mkdir gateway
cd gateway/
jhipster
We have now generated the gateway application, but we still need to explicitly ask JHipster to create the UI of the CRUD functionalities for the Position entity we had previously created for the Microservice. Let's ask for JHipster to create it now: Run JHipster's command.
jhipster entity position
In order to generate the entity, select the option to generate an entity for an existent Microservice and point it towards the Microservice path. As you can see, JHipster will do all the heavy-lifting for us:
The last step we need to complete is to generate a docker compose file to handle all Microservices, gateways, and their dependent services. So, let’s take a step back to the root directory and create a docker folder before running the JHipster command:
cd ../
mkdir docker
cd docker/
jhipster docker-compose
JHipster will ask some questions and here's what we should answer:
Type of application: Microservice application
Root directory for gateway and Microservices: ../
Applications to include: gateway, orderbook
Monitoring: Prometheus
Admin password to secure JHipster Registry: admin
We are now done with the generation code. Let's exit the JHipster generator container and spin up all the services we've created. Go to each application, generate a docker image, and then go to docker folder to start the containers:
exit
cd orderbook/
./gradlew -Pprod bootRepackage buildDocker
cd ../gateway/
./gradlew -Pprod bootRepackage buildDocker
cd ../docker/
docker-compose up
Let's see if JHipster generated everything correctly for us. You should get all applications up and running in a few minutes. Check the logs to see if you see the following messages:
jhipster-registry_1 | Application 'jhipster-registry' is running! Access URLs:
jhipster-registry_1 | Local: http://localhost:8761
...
orderbook-app_1 | Application 'orderbook' is running! Access URLs:
orderbook-app_1 | Local: http://localhost:8081
...
gateway-app_1 | Application 'gateway' is running! Access URLs:
gateway-app_1 | Local: http://localhost:8080
Accessing http:/localhost:8080, you can now see your gateway's welcome page:
Use admin/admin to sign in and go to the Entities > Position Menu. Now, we are at the Position list page and we can create our very first entry by clicking on Create new Position. Fill in the fields and click on Save. You should see a page similar to this one:
Congratulations! Now not only do you have both the gateway and Microservice up and running, but also a full end-to-end CRUD for an entity. There are so many other cool things JHipster can do for us but I’ll save that for another post. Until then, I'd love to hear from you: Have you ever used JHipster before? Do you know of any other similar solutions? Has this tutorial worked for you? You can head over to my GitHub page and check this tutorial code. See you next time!