Skip to content
This repository has been archived by the owner on Mar 23, 2023. It is now read-only.

Development How to JHipster Microservices

IT-REX-Platform edited this page Mar 31, 2021 · 9 revisions

Preliminary

We decided on Feb 12, 2021 to stop using the DSL provided by jHipster, the JDL, for the development of our application. We will only use the JDL in order to set-up the application structure. So we specifically use the JDL to persist the set-up of each backend-component, namely the Gateway and each single Microservice.

Reasoning: The JDL allows the specification of entities, which results in the automatic creation of a full-blown CRUD-Application based on Spring Boot. The generated code works well, but does not provide all options we need. Adapting the generated code to specific needs however is impossible due to overriding behaviour and non-working flags in the jHipster generator.

Consequently, using the JDL is only relevant for you, dear reader, if you want to create a new microservice! [Or if you, if it so happens, want to adapt the existing set-up which you should consider carefully.]

We version the JDL-files in our central JDL Git-Repository.

Working with JHipster Microservices

This chapter describes how we work with the project structure created with the JHipster generator. I.e., we describe how we put our code in an existing JHipster microservice.

If you want to set-up a new microservice, continue reading Creating a new Microservice with JHipster.

Preconditions

  1. Follow the Enviornment Setup.

  2. Clone repositories from GitHub.

  • Backend (Recommendation: Create new directory 'Backend' and clone all repositories in there):
  • [optional] Frontend: [email protected]:IT-REX-Platform/Frontend.git

written-Packages

Unfortunately, as the JHipster generator does not properly respond to all flags and configuration options, we cannot avoid generated code at all times. In order to avoid interfering with generated code and the JHipster generator, we decided to move all custom Java code to subpackages named written. Accordingly, this is the resulting package structure:

  • src/main/java/de.uni_stuttgart.it_rex.ABC
    • domain
      • written
    • respository
      • written
    • service
      • written
    • web.rest
      • written

Remember to create these packages if they do not yet exist when you implement new functionality.

Implementing Business Logic

After the decision to stop using the JDL for the creation of custom domain entities, we decided to add the required Java-Classes manually, as we will also need manual implementation in order to fullfill our requirements. All classes should therefore be added in the written-Packages described above.

Follow the structure introduced in the Spring Boot Workshop (see docs): Entities, Repositories, Services and RestControllers. Add the Java code to the package structure described above, specifically add the Entities to the domain.written-package and RestControllers to web.rest.written.

Running Microservices

Follow the documentation for starting the backend consisting of multiple microserivces. If want to implement backend logic, the partial set-up is for you 😉.

ℹ️ Encountered errors while executing and how to resolve them
  • OS: Windows - While running the main class - :openApiGenerate is failing
    javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed
    When you see this error, check which Java version your IntelliJ is using - we need Java 11. You can do this under File - Project Structure - Project Settings

  • OS: Windows - While running the main class
    Command line is too long. Shorten command line for GatewayApp or also for Spring Boot default configuration?
    Go Into your run configuration - open the sub-menu Environment - In the select fiel Shorten Command Line change the value to: @argfile (Java 9+) instead of user-local default:none

Creating new Microservices with JHipster

This chapter describes how to create a new microservice with JHipster.

Preconditions

What needs to be installed and how?

  1. Follow the Enviornment Setup.

  2. jHipster generator

  • Via NPM:
    npm install -g generator-jhipster
    This will install the most up-to-date version. Currently, this is 6.10.5 which is also the version we are using. To install this specific version, use
    npm install -g [email protected]
  • Alternatively with Docker:
    docker container run --name jhpster_generator -v $(pwd):/home/jhipster/app -v ~/.m2:/home/jhipster/.m2 -p 8080:8080 -p 9000:9000 -p 3001:3001 -it --rm jhipster/jhipster:v6.10.5 bash
    

JDL

The JDL documentation can be found here: https://www.jhipster.tech/jdl/. Be careful, as most flags do not work as indicated in the documentation! We list all flags we use in JDL Options in Use.

IT-REX JDL Files

We store all JDL-files in our central JDL Git-Repository. Consequently, the single project repositiries for each microservice do not contain JDL-files, so do not bother searching for them 😉. Each microservice is specified in an individual JDL-file however, but the files are still stored centrally.

JDL-Files can be edited with JDL-Studio or VS-Code.

JDL Options in Use

We only use the JDL for generation of the project containing the single application components, i.e. the microservices and the gateway. Consequently, we only use JDL options regarding the application configuration. The documenation is available here: https://www.jhipster.tech/jdl/applications#available-application-configuration-options. Be careful: not everything works as intended.

Most of these options can also be set manually using the JHipster generator in interactive mode, or passing command-line flags to the generator. We decided to use the following options via the JDL:

The following options should be used to create new microservices, see also Create new Microservices.

  • baseName - to be set for each serivce, unique name
  • applicationType gateway | microservice - one gateway, many microservices
  • packageName de.uni_stuttgart.it_rex.ABC - set the name of your base java package
  • serverPort - specify your server port here
  • prodDatabaseType postgresql - choose your production db
  • devDatabaseType h2Disk - choose your development db

The following flags should be rather stable - no need to change anything.

  • authenticationType oauth2 (do not change!)
  • serviceDiscoveryType eureka (do not change!)
  • skipClient true (only for gateway, set for microservices per default)
  • skipUserManagement true (currently not working with jhipster-generator 6.10.5, see https://github.com/jhipster/generator-jhipster/issues/12366)
  • testFrameworks [] (do not change!)
  • buildTool gradle (do not change!)
  • cacheProvider hazelcast (do not change!)
  • nativeLanguage en (do not change!)
  • languages [de] (do not change!)
  • enableSwaggerCodegen true (enable or disabel generation of a swagger/OpenAPI Spec)

Additionally, some flags are useful when operating the JHipster generator to update existing components, see more at Updating Microserivces.

Steps to create a new Microservice

  1. Clone the JDL-Repository (Recommendation: inside the Backend-dir containing all exising microserices):

    git clone https://github.com/IT-REX-Platform/JDL.git
    
  2. Create a new JDL file based on the template available in the JDL-Repository at configfiles/MicroserviceTemplate.jdl (we will call the new service MyNewRexService and the JDL-File MyNewRexService.jdl). Use existing Microservices as Orientation and consider the list of JDL Options in Use

  3. Go to the Backend-dir in and create a new directory called MyNewRexService

    • navgiate inside the new directory
    • execute the jdl to generate the service with:
    jhipster import-jdl path-to-JDL-repository/MyNewRexService.jdl
    • discard changes in every project except for the newly generated one and the Gateway (to avoid overriding important changes done by others). Discard Changes: Git command (git reset o.ä.)
  4. Replace the auto-generated configuration for SonarQube in sonar-project.properties with the file stored in the JDL-repository (see: configfiles/sonar-project.properties).

  5. You may discard the following files (they are only used for a in-repo installation of the JHipster generator as well as client-app stuff, which we both don't make use of). This list is probably incomplete. Authority and Auditing classes are also not used at the moment and probably removed/replaced or adapted to project needs.

    • .husykrc
    • .lintstagedrc.js
    • .prettierignore
    • .prettierrc
    • node_modules
    • package.json
    • package-lock.json
    • src/main/java/<package name>/domain/User.java
    • src/main/java/<package name>/repository/UserRepository.java
    • src/main/java/<package name>/service/dto/package-info.java
    • src/main/java/<package name>/service/dto/UserDTO.java
    • src/main/java/<package name>/service/mapper/UserMapper.java
    • src/main/java/<package name>/service/UserService.java
    • src/main/java/<package name>/web/rest/UserResource.java
    • src/main/java/<package name>/web/rest/vm/
    • src/main/java/<package name>/web/rest/vm/ManagedUserVM.java
    • src/main/java/<package name>/web/rest/vm/package-info.java
    • src/test/java/<package name>/service/mapper/UserMapperTest.java
    • src/test/java/<package name>/service/UserServiceIT.java
    • src/test/java/<package name>/web/rest/UserResourceIT.java
  6. Add RexAuthz lib to your service. At the moment there is no external lib, so you have to copy the files from e.g. MediaService:

    • src/main/java/<package name>/domain/written/enumeration/COURSEROLE.java
    • src/main/java/<package name>/domain/written/enumeration/REXROLE.java
    • src/main/java/<package name>/security/written/RexAuthz.java
    • src/main/java/<package name>/security/written/RexAuthzConstants.java
    • src/main/java/<package name>/security/written/RexAuthzException.java
  7. In src/main/resources/config/application.yml set "issuer-uri" to "http://keycloak:9080/auth/realms/jhipster"

  8. Add a beautiful ascii art greeting in: src/main/resources/banner.txt :)

   _____ ______ _______      _______ _____ ______ 
  / ____|  ____|  __ \ \    / /_   _/ ____|  ____|
 | (___ | |__  | |__) \ \  / /  | || |    | |__   
  \___ \|  __| |  _  / \ \/ /   | || |    |  __|  
  ____) | |____| | \ \  \  /   _| || |____| |____ 
 |_____/|______|_|  \_\  \/   |_____\_____|______|
  1. Create GitHub repository and push initial commit
  2. [If you implement new functionality]: Remember to add the written-packages as described earlier.

👏 Congrats! You created a new microservice!

You might want to consider integrating it into the CI/CD as well.

Updating existing microservices with JHipster

⚠️ Be cautious when updating microservices with JHipster!

After our decision to not using JHipster for the creation of entities etc, updating a microservice should usually not happen again.

If you encounter the situation that you have to alter the application configuration of your microservice, you have two general options:

  • Perform the changes manually. Suggestion: Make a comment in the microservice's JDL-file that you did so and the JDL-file might represent the latest configuration anymore.

  • Use the JHipster generator to update the config. Existing files will change/be overriden. It is not clearly documented, which files are affected, so always use caution! ⚠️ Useful flags:

    • --force: force the changes to be performed (shoud however, if the docs are correct, only influence entities)
    • --ignore-application: do not use this flag to update your application, because it won't.

    Only listed here, because usage is often encouraged when updating entities and stuff (which we do not do).

Clone this wiki locally