Short feedback cycles during development are essential for your productivity. If you practice TDD you’ll agree on this even more. In the past, I’ve used several IDE plugins to achieve this for developing Jakarta EE applications. All worked but it wasn’t joyful. Adam Bien’s Watch and Deploy was a light at the end of the tunnel for a simple & generic solution. Recently I stumbled over the Liberty Maven Plugin from the Open Liberty team. This is really a gamechanger for great development experience for Liberty profile servers.
TL;DR: You’ll achieve the following with this Maven plugin:
- Hot-reloading of code/configuration/dependency changes
- TDD joy for developing Jakarta EE and MicroProfile applications
- Easily debug your deployed application
- Start your Open Liberty server without manual effort
Integrate the Liberty Maven Plugin to your project
Integrating this Open Liberty Maven plugin to an existing project, is as simple, like the following:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>de.rieckpil.blog</groupId> <artifactId>open-maven-plugin-review</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <properties> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <failOnMissingWebXml>false</failOnMissingWebXml> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <jakarta.jakartaee-api.version>8.0.0</jakarta.jakartaee-api.version> <microprofile.version>3.2</microprofile.version> <junit-jupiter.version>5.5.0</junit-jupiter.version> </properties> <dependencies> <dependency> <groupId>jakarta.platform</groupId> <artifactId>jakarta.jakartaee-api</artifactId> <version>${jakarta.jakartaee-api.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.eclipse.microprofile</groupId> <artifactId>microprofile</artifactId> <version>${microprofile.version}</version> <type>pom</type> <scope>provided</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter</artifactId> <version>${junit-jupiter.version}</version> <scope>test</scope> </dependency> </dependencies> <build> <finalName>open-maven-plugin-review</finalName> <plugins> <plugin> <groupId>io.openliberty.tools</groupId> <artifactId>liberty-maven-plugin</artifactId> <version>3.1</version> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> </plugin> <plugin> <artifactId>maven-surefire-plugin</artifactId> <version>2.22.2</version> </plugin> </plugins> </build> </project> |
Open Liberty server configuration
By default, the plugin makes use of your configuration within src/main/liberty
. To now configure the server, we can place our server.xml
within src/main/liberty/config
:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
<?xml version="1.0" encoding="UTF-8"?> <server description="rieckpil"> <featureManager> <feature>cdi-2.0</feature> <feature>jpa-2.2</feature> <feature>jaxrs-2.1</feature> <feature>mpConfig-1.3</feature> <feature>mpHealth-2.0</feature> <feature>mpRestClient-1.3</feature> </featureManager> <httpEndpoint id="defaultHttpEndpoint" httpPort="9080" httpsPort="9443"/> <!-- ${databaseName} is configured in the pom.xml --> <dataSource id="DefaultDataSource" jndiName="jdbc/h2"> <jdbcDriver libraryRef="h2-library"/> <properties URL="jdbc:h2:mem:${databaseName}"/> </dataSource> <library id="h2-library"> <file name="${server.config.dir}/h2.jar"/> </library> </server> |
If you, later on, start the Open Liberty server, you’ll find this file within target/liberty/wlp/usr/servers/defaultServer
. To provide further resources e.g. a JDBC driver like in the example above, just place them next inside the same directory like your server.xml
. You can also create new folder structures to separate the files from each other.
Similar to this, you can configure server parameters like environment, JVM or Liberty specific variables with this plugin. Since plugin version 3.1, you can achieve this within the properties
section of your pom.xml
:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
<properties> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <failOnMissingWebXml>false</failOnMissingWebXml> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <jakarta.jakartaee-api.version>8.0.0</jakarta.jakartaee-api.version> <microprofile.version>3.2</microprofile.version> <junit-jupiter.version>5.5.0</junit-jupiter.version> <!-- Configuration for Open Liberty --> <liberty.jvm.minHeap>-Xms512m</liberty.jvm.minHeap> <liberty.env.MY_MESSAGE>Hello World from Maven pom.xml!</liberty.env.MY_MESSAGE> <liberty.var.databaseName>jakarta</liberty.var.databaseName> </properties> |
The liberty.env
can be then used for example by MicroProfile Config. The liberty.var
variables are available within your server.xml
for further configuration like it did with the name of the H2 database.
Find a list of all possible server configurations here.
Open Liberty in development mode = joy
Now comes the joyful part…
With this plugin you can launch the Open Liberty server on your machine in development mode:
mvn liberty:dev
If you execute this for the first time, the plugin will download the openliberty-kernel
and all the required features you need. These files are stored within your local Maven repository folder (usually ~/.m2/repository
) and can be therefore used for multiple projects.
Once all artifacts are downloaded, your Open Liberty server starts in development mode. If you now change the source code of your application, the plugin compiles and deploys your changes to the running server in a matter of seconds.
This is not limited to changes to your code. You can also add new dependencies to your Maven project or adjust your server configuration. Even if you add new features to your server.xml
, they will be installed automatically.
Furthermore, you can run your (unit & integration) tests on-demand with hitting enter. In addition to this, if you start the development mode with -DhotTests
, your tests are executed on each change:
mvn liberty:dev -DhotTests
This is a gamechanger for the TDD (Test Driven Development) experience with Open Liberty.
Once Open Liberty is running in this development mode, you can also debug your application. The default port is 7777 and you can easily attach your IDE to the running JVM and debug your application.
To exit the development mode, either enter q
in your terminal and hit enter or exit with CTRL+C.
Other Maven plugin goals
Besides this development mode, you can also start and stop your Open Liberty server with this project. The Maven goals for this are mvn liberty:start
and mvn liberty:stop
. The server content is located at target/liberty
. There is no need to manually download Open Liberty anymore, as this plugin will do this.
If you want to start Open Liberty in the foreground, replace the start
goal with run
.
There are more useful goals for this Maven plugins to explore e.g dump
, debug
, create
. The full list of goals is available on GitHub.
Summary of the Open Liberty Maven Plugin
With this Maven plugin, your Jakarta EE or MicroProfile development experience will takeoff. Given this plugin, there is no need to download the latest server anymore. The conventions for the server configuration makes it also more convenient to use compared to achieving the same with Docker. This plugin will definitely be part of all my further Open Liberty projects and I can’t imagine developing applications without it anymore.
For a hands-on example, I’ve recorded a YouTube video:
Clone the example application for this review from GitHub or quickly add the plugin to your own project to see how joyful it makes developing with Open Liberty. There is also a recording available at the Open Liberty blog.
If you are looking for a solution to achieve hot reloading for other application servers, have a look at Adam Bien’s WAD.
Have fun using the Open Liberty Maven Plugin,
Phil