š¦ How to Create EAR File Using Maven?
Note: This post was originally published in 2013. While Maven remains a fundamental build tool, modern Java development often uses Gradle or cloud-native approaches. However, the principles of multi-module project management remain relevant.
It's much easier to create and understand the creation process of JAR, WAR using Maven build tool. But creation of Enterprise application is a bit confusing and yet a bit interesting too with the use of the "Reactor" plugin!
Just hang on with us for a while to know how to create EAR file using Maven build management tool.
Implementation Part
Step 1: Project Structure
Consider the following scenario; in my cricket project, I have developed three different types of Applications:
- myearproject-dhoni-web ā We need to bundle this as a separate WAR file using its own pom.xml
- myearproject-dravid-web ā We need to bundle this as a separate WAR file using its own pom.xml
- myearproject-sachin-web ā We need to bundle this as a separate WAR file using its own pom.xml
Step 2: Generate WAR Files
Once this WAR files generation is completed for all 3 modules, finally we need to put it all together and generate an EAR file. Refer to the following diagram for reference.
Project Structure:
myearproject/
āāā pom.xml (parent)
āāā myearproject-ear/
ā āāā pom.xml (EAR module)
āāā myearproject-dhoni-web/
ā āāā pom.xml (WAR module)
āāā myearproject-dravid-web/
ā āāā pom.xml (WAR module)
āāā myearproject-sachin-web/
āāā pom.xml (WAR module)Step 3: Project Aggregation
Here we have a separate pom.xml file for individual projects which would perform WAR file generation. And finally, we need to create a special project called "multi-module project" in Maven terms. It will not create any JAR or WAR artifacts, it just aggregates all other projects as "Modules".
Multi-Module Project POM File
Parent POM file that aggregates all modules:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany</groupId>
<artifactId>myearproject</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject Maven Enterprise Application</name>
<url>http://maven.apache.org</url>
<modules>
<module>myearproject-ear</module>
<module>myearproject-sachin-web</module>
<module>myearproject-dravid-web</module>
<module>myearproject-dhoni-web</module>
</modules>
</project>Module I: myearproject-dhoni-web
WAR module for Dhoni web application:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<artifactId>myearproject</artifactId>
<groupId>com.mycompany</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dhoni-web</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject-dhoni-web</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-web-api</artifactId>
<version>6.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>Module II: myearproject-dravid-web
WAR module for Dravid web application:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<artifactId>myearproject</artifactId>
<groupId>com.mycompany</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dravid-web</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject-dravid-web</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-web-api</artifactId>
<version>6.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>Module III: myearproject-sachin-web
WAR module for Sachin web application:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<artifactId>myearproject</artifactId>
<groupId>com.mycompany</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-sachin-web</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject-sachin-web</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-web-api</artifactId>
<version>6.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>Module IV: myearproject-ear
EAR module that packages all WAR files:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<artifactId>myearproject</artifactId>
<groupId>com.mycompany</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-ear</artifactId>
<packaging>ear</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject-ear</name>
<url>http://maven.apache.org</url>
<dependencies>
<!-- WAR dependencies -->
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dhoni-web</artifactId>
<version>1.0-SNAPSHOT</version>
<type>war</type>
</dependency>
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dravid-web</artifactId>
<version>1.0-SNAPSHOT</version>
<type>war</type>
</dependency>
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-sachin-web</artifactId>
<version>1.0-SNAPSHOT</version>
<type>war</type>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-ear-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<finalName>myearproject</finalName>
<applicationName>myearproject</applicationName>
<initializeInOrder>true</initializeInOrder>
<archive>
<manifest>
<addClasspath>true</addClasspath>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
</project>Application.xml Configuration
Create the application.xml file in the EAR module's src/main/application/META-INF/ directory:
<?xml version="1.0" encoding="UTF-8"?>
<application xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/application_6.xsd"
version="6">
<display-name>myearproject</display-name>
<description>My Enterprise Application</description>
<!-- Web modules -->
<module>
<web>
<web-uri>myearproject-dhoni-web-1.0-SNAPSHOT.war</web-uri>
<context-root>/dhoni</context-root>
</web>
</module>
<module>
<web>
<web-uri>myearproject-dravid-web-1.0-SNAPSHOT.war</web-uri>
<context-root>/dravid</context-root>
</web>
</module>
<module>
<web>
<web-uri>myearproject-sachin-web-1.0-SNAPSHOT.war</web-uri>
<context-root>/sachin</context-root>
</web>
</module>
</application>Build Commands
Commands to build the entire project:
# Build all modules mvn clean install # Build only the EAR module mvn clean install -pl myearproject-ear # Build with specific profile mvn clean install -Pproduction # Build with debug information mvn clean install -X
Advanced EAR Configuration
Enhanced EAR plugin configuration with additional options:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-ear-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<finalName>myearproject</finalName>
<applicationName>myearproject</applicationName>
<initializeInOrder>true</initializeInOrder>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
</manifest>
</archive>
<!-- Web module configuration -->
<webModule>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dhoni-web</artifactId>
<contextRoot>/dhoni</contextRoot>
</webModule>
<webModule>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dravid-web</artifactId>
<contextRoot>/dravid</contextRoot>
</webModule>
<webModule>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-sachin-web</artifactId>
<contextRoot>/sachin</contextRoot>
</webModule>
<!-- Security configuration -->
<security>
<securityRole>
<roleName>admin</roleName>
<principalName>admin</principalName>
</securityRole>
</security>
</configuration>
</plugin>Multi-Module Project Best Practices
- Parent POM: Define common properties and dependencies in parent POM
- Version Management: Use dependency management for consistent versions
- Module Order: Ensure proper build order with dependencies
- Profiles: Use Maven profiles for different environments
- Testing: Include integration tests for EAR deployment
- Documentation: Document module dependencies and relationships
Parent POM with Dependency Management
Enhanced parent POM with dependency management:
<?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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany</groupId>
<artifactId>myearproject</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<name>myearproject Maven Enterprise Application</name>
<url>http://maven.apache.org</url>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<javaee.version>6.0</javaee.version>
<maven-ear-plugin.version>3.2.0</maven-ear-plugin.version>
</properties>
<modules>
<module>myearproject-ear</module>
<module>myearproject-sachin-web</module>
<module>myearproject-dravid-web</module>
<module>myearproject-dhoni-web</module>
</modules>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-web-api</artifactId>
<version>${javaee.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dhoni-web</artifactId>
<version>${project.version}</version>
<type>war</type>
</dependency>
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-dravid-web</artifactId>
<version>${project.version}</version>
<type>war</type>
</dependency>
<dependency>
<groupId>com.mycompany</groupId>
<artifactId>myearproject-sachin-web</artifactId>
<version>${project.version}</version>
<type>war</type>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-ear-plugin</artifactId>
<version>${maven-ear-plugin.version}</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>Deployment Configuration
Example deployment configuration for different application servers:
WebLogic Deployment
# WebLogic deployment command java weblogic.Deployer -adminurl t3://localhost:7001 -username weblogic -password weblogic123 -deploy -name myearproject -source myearproject-ear/target/myearproject.ear
JBoss Deployment
# JBoss deployment command cp myearproject-ear/target/myearproject.ear /opt/jboss/standalone/deployments/
Modern Alternatives
While Maven EAR projects are still valid, modern alternatives include:
- Microservices: Deploy individual WAR files as separate services
- Docker Containers: Containerize each web application
- Kubernetes: Orchestrate microservices with Kubernetes
- Spring Boot: Use embedded containers instead of EAR deployment
- Cloud Platforms: Deploy to cloud platforms like AWS, Azure, GCP
- Gradle: Use Gradle for more flexible build configuration
Troubleshooting
Common issues and solutions:
- Classpath Issues: Ensure proper classpath configuration in application.xml
- Version Conflicts: Use dependency management to resolve conflicts
- Build Order: Verify module dependencies and build order
- Deployment Failures: Check application server logs for deployment errors
- Context Root Conflicts: Ensure unique context roots for web modules
Key Takeaways
- Maven multi-module projects enable complex enterprise application packaging
- EAR files provide a way to deploy multiple web applications as a single unit
- Proper dependency management is essential for successful builds
- Application.xml configuration defines the deployment structure
- Modern alternatives offer more flexibility and scalability