Apache Maven Eclipse Integration Tutorial
Apache Maven Eclipse Integration aims to ease developers to update pom.xml
in the Eclipse IDE. In this tutorial, I will demonstrate how to create, build, and modify a Maven project in the Eclipse IDE.
Table Of Contents
1. Introduction
Apache Maven is a software project management tool. Maven can manage a project’s build, report, and documentation from a central piece of information based on a Project Object Model (POM). Eclipse is an integrated development environment (IDE) used in computer programming, and is the most widely used Java IDE. M2Eclipse (M2E) is the official Eclipse project for Maven integration for the Eclipse IDE.
The goal of M2E is to support Maven in the Eclipse IDE, making it easier to edit Maven’s pom.xml
and run a build from the IDE. In this tutorial, I will show you how to create, build, and manage a Maven project inside Eclipse.
2. Install Eclipse
First, click here to install JDK 8, then click here to install Eclipse. If you already have JDK and Eclipse installed, you can skip this step.
3. Install Maven
Eclipse IDE comes with Maven already embedded, but it’s not suitable to execute Maven commands outside of Eclipse. Please click here to install Maven.
We need to set up Maven environment variable. Click here for instruction on windows OS.
Note: M2_HOME is the environment variable name for Maven 2.x and 3.x. MAVEN_HOME is the environment variable name for Maven 1.x.
3.1 Settings.xml
A Maven settings.xml file defines configurable property values. For example, it defines a local repository location, alternate remote repository servers, and authentication information for private repositories.
- Global setting –
${M2_HOME}/conf/settings.xml
- User setting –
${user.home}/.m2/settings.xml
. The user setting is optional.
Note: The user setting takes precedence over the global setting for the same configuration elements.
4. Install M2Eclipse
M2E is bundled in Eclipse since version Luna which was released on June 25, 2014. Click here for Eclipse with a version older than Luna.
4.1 Check If M2E is Installed or Not
Launch Eclipse, then click Help->About Eclipse IDE
, then click the Installation Details
button.
data:image/s3,"s3://crabby-images/0c632/0c6327af2ac2bdc6ea5e0fa2681c4a4060f42bda" alt="Apache Maven Eclipse Integration - Installation Details"
M2E is installed if m2e
is displayed like shown.
4.2 Configure Maven in Eclipse
Launch Eclipse, and click Windows->Preferences->Maven
. We will update two maven settings: installation and user setting.
4.2.1 Installation
Click add
, and enter the Maven home directory as shown.
data:image/s3,"s3://crabby-images/bc9ec/bc9ec4de7c4988e59d9878874d9f5b8c1d082724" alt="Apache Maven Eclipse Integration - Maven Installations Setting"
4.2.2 User Setting
Enter the user setting location and the local repository as shown.
data:image/s3,"s3://crabby-images/0d2b3/0d2b36daca701c6da85ce331715761d705e49a80" alt="Apache Maven Eclipse Integration - Maven User Setting"
5. Create a New Maven Project
M2E enables developers to create a new Maven project in the Eclipse IDE.
First, launch Eclipse, then click File->New->Other…->Maven->Maven Project
.
data:image/s3,"s3://crabby-images/8e84e/8e84e634c23797fb1468a2b3a789b5ef69b0e950" alt="Apache Maven Eclipse Integration - Maven Project"
It will open a new window after Next
is clicked. Check the “create a simple project” option.
data:image/s3,"s3://crabby-images/d1ab2/d1ab29031769cda1f7009b70d6b1bffcccc5d8c9" alt="Apache Maven Eclipse Integration - Simple Project"
Click Next
, then enter the group id, artifact id, and version of your project .
data:image/s3,"s3://crabby-images/07867/07867b61f1136d68c947874e0af767455f21f8ff" alt="Apache Maven Eclipse Integration - Project GAV"
Click Finish
. It will generate a new project with a standard Maven folder structure.
data:image/s3,"s3://crabby-images/75767/757674c4789f2e8a55155021362e6d0ea608a518" alt="Apache Maven Eclipse Integration - Generated Project"
Click here to create a new maven project based on a maven archetype.
6. Build Project
Now, you have a generated Maven project. Right-click it to open a pop-up window. Select Run As->Maven Install
to build it.
data:image/s3,"s3://crabby-images/5aa25/5aa2516fb6751ffec5ea525adecb92b55f9e7031" alt="Apache Maven Eclipse Integration - Build a Project"
You should monitor the console view in Eclipse IDE which outputs the Maven build result. You should receive a “BUILD SUCCESS” message when it finishes.
You can execute other maven commands: clean, test, build, etc in Eclipse IDE.
6.1 Build with a Customized Command
You can build a project with a customized configuration in Eclipse IDE.
Right-click the project and select Run As->Maven Build...
. It will open up a window.
data:image/s3,"s3://crabby-images/8e41f/8e41f51dd6a1f9709c1298dad20cc4f6515ea40e" alt="Apache Maven Eclipse Integration - Customized Build"
Enter the customized Maven goal and profile if there is any.
data:image/s3,"s3://crabby-images/e5edf/e5edfc5bade1cdd2d069b1b65c4650b7a0e5274a" alt="Apache Maven Eclipse Integration - Configure a Run As"
Click Apply
and Run
to execute it.
7. Manage Project
You can add dependencies and plug-ins by updating pom.xml
. The M2E plug-in makes these tasks easily done in the Eclipse IDE.
7.1 Add Dependencies
Right-click the project, select Maven->Add dependency
.
data:image/s3,"s3://crabby-images/7c6e6/7c6e6db1127e5b6f431654e02acb8c3fe4b50b4e" alt="Apache Maven Eclipse Integration - Add Dependency"
It will open a window to fill the dependency details. I will use Junit as an example here.
data:image/s3,"s3://crabby-images/a0b68/a0b68741390712da9feadcea9fb30551c4e3d3ec" alt="Apache Maven Eclipse Integration - Add Junit"
After clicking OK
, you should see that pom.xml
is updated with Junit
.
pom.xml
<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>org.jcg.zheng</groupId> <artifactId>maven-eclipse-demo</artifactId> <version>0.0.1-SNAPSHOT</version> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> </dependencies> </project>
7.2 Create a New Maven Module
If you want to add a new maven module to the current project, you can do so by right-clicking it and select Maven->New Module Project
and follow the steps in the pop-up windows.
Please click here for detailed instructions.
7.3 Convert to a Maven Project
If you have a non-maven project and want to convert it to a Maven project. You can do so by right-clicking it and select Configure->Convert to Maven Project
.
data:image/s3,"s3://crabby-images/8a84b/8a84b903f3b82da2f9829961b4e64912ac89b77f" alt="Apache Maven Eclipse Integration - Convert to a Maven Project"
8. Troubleshooting Tips
Here are some useful tips when troubleshooting a Maven project in the Eclipse IDE.
8.1 Class Path File
Eclipse Java development tools (JDT) relies on the .classpath
file to compile a project. It defines a project’s source folders, output folders, and class path entries. Maven super pom
defaults the source folder and output folders.
If Eclipse IDE does not load the Maven dependencies for a Maven project, then you can fix it by correcting its .classpath
file. Here is an example of a .classpath
file which you can use in your project.
.classpath
<?xml version="1.0" encoding="UTF-8"?> <classpath> <classpathentry kind="src" path="src/main/java"/> <classpathentry kind="src" output="target/test-classes" path="src/test/java"> <attributes> <attribute name="test" value="true"/> </attributes> </classpathentry> <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"> <attributes> <attribute name="owner.project.facets" value="java"/> </attributes> </classpathentry> <classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER"> <attributes> <attribute name="maven.pomderived" value="true"/> </attributes> </classpathentry> <classpathentry kind="output" path="target/classes"/> </classpath>
8.2 Clean Project
Clicking Project->Clean...
usually clears Eclipse IDE errors.
data:image/s3,"s3://crabby-images/94d82/94d8259d67f41f09e1a6daf5736339e6ccca8db6" alt="Apache Maven Eclipse Integration - Project Clean"
As you see here, it has two options: one to build the entire workspace and one to build only the selected projects.
8.3 Update Project
Right-click the project and select Maven->update project...
.
data:image/s3,"s3://crabby-images/82021/82021c57efd36dc6d4f9cde2311b2122ebe54d75" alt="Apache Maven Eclipse Integration - Update Project"
Click OK
to update the project.
9. Apache Maven Eclipse Integration – Summary
Apache provides maven-eclipse-plugin to integrate Maven in Eclipse, but it is retired in 2015. M2Eclipse is the official Eclipse project for Maven integration for the Eclipse IDE.
In this tutorial, I demonstrated how to create a new Maven project, how to build a project, how to add a dependency, and some useful troubleshooting tips in Eclipse IDE.