Chapter 4. Develop MicroProfile applications for JBoss EAP
To get started with developing applications that use MicroProfile APIs, create a Maven project and define the required dependencies. Use the JBoss EAP MicroProfile Bill of Materials (BOM) to control the versions of runtime Maven dependencies in the application Project Object Model (POM).
After you create a Maven project, refer to the JBoss EAP XP Quickstarts for information about developing applications for specific MicroProfile APIs. For more information, see JBoss EAP XP Quickstarts.
4.1. Creating a Maven project with maven-archetype-webapp
Use the maven-archetype-webapp
archetype to create a Maven project for building applications for JBoss EAP deployment. Maven provides different archetypes for creating projects based on templates specific to project types. The maven-archetype-webapp
creates a project with the structure required to develop simple web-applications.
Prerequisites
- You have installed Maven. For more information, see Downloading Apache Maven.
Procedure
Set up a Maven project by using the
mvn
command. The command creates the directory structure for the project and thepom.xml
configuration file.$ mvn archetype:generate \ -DgroupId=<group_id> \1 -DartifactId=<artifact_id> \2 -DarchetypeGroupId=org.apache.maven.archetypes \3 -DarchetypeArtifactId=maven-archetype-webapp \4 -DinteractiveMode=false 5
- 1
groupID
uniquely identifies the project.- 2
artifactID
is the name for the generatedjar
archive.- 3
archetypeGroupID
is the unique ID formaven-archetype-webapp
.- 4
archetypeArtifactId
is the artifact ID formaven-archetype-webapp
.- 5
InteractiveMode
instructs Maven to use the supplied parameters rather than starting in interactive mode.
- Navigate to the generated directory.
-
Open the generated
pom.xml
configuration file in a text editor. Remove the content inside the
<project>
section of thepom.xml
configuration file after the<name>helloworld Maven Webapp</name>
line.Ensure that the file looks like this:
<?xml version="1.0" encoding="UTF-8"?> <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>${group_id}</groupId> <artifactId>${artifact_id}</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>${artifact_id} Maven Webapp</name> </project>
The content was removed because it is not required for the application.
Next steps
4.2. Defining properties in a Maven project
You can define properties in a Maven pom.xml
configuration file as place holders for values. Define the value for JBoss EAP XP server as a property to use the value consistently in the configuration.
Prerequisites
You have initialized a Maven project.
For more information, see Creating a Maven project with
maven-archetype-webapp
.
Procedure
Define a property
<version.bom.microprofile>
as the JBoss EAP XP version on which you will deploy the configured application.<project> ... <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <version.bom.microprofile>5.0.0.GA-redhat-00009</version.bom.microprofile> </properties> </project>
Next steps
4.3. Defining the repositories in a Maven project
Define the artifact and plug-in repositories in which Maven looks for artifacts and plug-ins to download.
Prerequisites
You have initialized a Maven project.
For more information, see Creating a Maven project with
maven-archetype-webapp
.
Procedure
Define the artifacts repository.
<project> ... <repositories> <repository> 1 <id>jboss-public-maven-repository</id> <name>JBoss Public Maven Repository</name> <url>https://repository.jboss.org/nexus/content/groups/public/</url> <releases> <enabled>true</enabled> <updatePolicy>never</updatePolicy> </releases> <snapshots> <enabled>true</enabled> <updatePolicy>never</updatePolicy> </snapshots> <layout>default</layout> </repository> <repository> 2 <id>redhat-ga-maven-repository</id> <name>Red Hat GA Maven Repository</name> <url>https://maven.repository.redhat.com/ga/</url> <releases> <enabled>true</enabled> <updatePolicy>never</updatePolicy> </releases> <snapshots> <enabled>true</enabled> <updatePolicy>never</updatePolicy> </snapshots> <layout>default</layout> </repository> </repositories> </project>
Define the plug-ins repository.
<project> ... <pluginRepositories> <pluginRepository> <id>jboss-public-maven-repository</id> <name>JBoss Public Maven Repository</name> <url>https://repository.jboss.org/nexus/content/groups/public/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </pluginRepository> <pluginRepository> <id>redhat-ga-maven-repository</id> <name>Red Hat GA Maven Repository</name> <url>https://maven.repository.redhat.com/ga/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </pluginRepository> </pluginRepositories> </project>
4.4. Importing the JBoss EAP MicroProfile BOM as dependency management in a Maven project
Import the JBoss EAP MicroProfile Bill of Materials (BOM) to control the versions of runtime Maven dependencies. When you specify a BOM in the <dependencyManagement>
section, you do not need to individually specify the versions of the Maven dependencies defined in the provided
scope.
Prerequisites
You have initialized a Maven project.
For more information, see Creating a Maven project with
maven-archetype-webapp
.
Procedure
Add a property for the BOM version in the properties section of the
pom.xml
configuration file.<properties> ... <version.bom.microprofile>5.0.0.GA-redhat-00009</version.bom.microprofile> </properties>
The value defined in the property
<version.bom.microprofile>
is used as the value for the BOM version.Import the JBoss EAP BOMs dependency management.
<project> ... <dependencyManagement> <dependencies> <dependency> <groupId>org.jboss.bom</groupId> 1 <artifactId>jboss-eap-xp-microprofile</artifactId> 2 <version>${version.bom.microprofile}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> </project>
Optionally, you can import the JBoss EAP EE with Tools Bill to your project. For more information, see Importing the JBoss EAP BOMs as dependency management in a Maven project.
Next steps
4.5. Importing the JBoss EAP BOMs as dependency management in a Maven project
You can optionally import the JBoss EAP EE With Tools Bill of materials (BOM). The JBoss EAP BOM provides supported JBoss EAP Java EE APIs plus additional JBoss EAP API JARs and client BOMs. You only need to import this BOM if your application requires Jakarta EE APIs in addition to the Microprofile APIs.
Prerequisites
You have initialized a Maven project.
For more information, see Creating a Maven project with
maven-archetype-webapp
.
Procedure
Add a property for the BOM version in the properties section of the
pom.xml
configuration file.<properties> .... <version.bom.ee>8.0.0.GA-redhat-00009</version.bom.ee> </properties>
Import the JBoss EAP BOMs dependency management.
<project> ... <dependencyManagement> <dependencies> <dependency> <groupId>org.jboss.bom</groupId> 1 <artifactId>jboss-eap-ee-with-tools</artifactId> 2 <version>${version.bom.ee}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> </project>
Next steps
4.6. Adding plug-in management in a Maven project
Add Maven plug-in management section to the pom.xml
configuration file to get plug-ins required for Maven CLI commands.
Prerequisites
You have initialized a Maven project.
For more information, see Creating a Maven project with
maven-archetype-webapp
.
Procedure
Define the versions for
wildfly-maven-plugin
andmaven-war-plugin
, in the<properties>
section.<properties> ... <version.plugin.wildfly>4.2.1.Final</version.plugin.wildfly> <version.plugin.war>3.3.2</version.plugin.war> </properties>
Add
<pluginManagement>
in<build>
section inside the<project>
section.<project> ... <build> <pluginManagement> <plugins> <plugin> 1 <groupId>org.wildfly.plugins</groupId> <artifactId>wildfly-maven-plugin</artifactId> <version>${version.plugin.wildfly}</version> </plugin> <plugin> 2 <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> <version>${version.plugin.war}</version> </plugin> </plugins> </pluginManagement> </build> </project>
Next steps
4.7. Verifying a maven project
Verify that the Maven project you configured builds.
Prerequisites
You have defined Maven properties.
For more information, see Defining properties in a Maven project.
You have defined Maven repositories.
For more information, see Defining the repositories in a Maven project.
You have imported the JBoss EAP Bill of materials (BOMs) as dependency management.
For more information, see Importing the JBoss EAP MicroProfile BOM as dependency management in a Maven project.
You have added plug-in management.
For more information, see Adding plugin management in Maven project for a server hello world application.
Procedure
Install the Maven dependencies added in the
pom.xml
locally.$ mvn package
You get an output similar to the following:
... [INFO] ------------------------------------------------------------------------ [INFO] BUILD SUCCESS [INFO] ------------------------------------------------------------------------ ...
For more information about developing applications for specific MicroProfile APIs, see JBoss EAP XP Quickstarts.
Additional resources