Creating and Using Custom Maven Archetypes
Introduction
Maven archetypes are templates that simplify the creation of new projects. They allow you to quickly generate project structures with predefined files, directories, and configurations. Custom Maven archetypes are particularly useful when your organization or team has specific conventions or configurations that need to be included in every new project.
In this article, we’ll go through the process of creating a custom Maven archetype step by step.
What is a Maven Archetype?
A Maven archetype is essentially a project skeleton. When you create a new Maven project from an archetype, 
Maven uses the template to generate a pre-defined project structure, including standard files like pom.xml, 
source directories, and resource directories.
Why Create a Custom Archetype?
By creating a custom archetype, you can:
- Standardize project structures across your organization.
- Pre-configure dependencies, plugins, and settings.
- Enforce best practices by embedding your coding guidelines into the project structure.
- Save time by avoiding repetitive setup for each new project.
Step-by-Step Guide to Creating a Custom Maven Archetype
Prerequisites
Before starting, ensure that you have the following installed:
- Maven: Version 3.0 or higher.
- JDK: Version 8 or higher.
- Git (optional): To manage version control for your archetype.
Step 1: Create a Maven Project as a Base
The first step in creating an archetype is to define a base project that will serve as the template. Create a new Maven project using your preferred archetype or structure:
1
mvn archetype:generate -DgroupId=com.example -DartifactId=my-app -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false
Once created, modify the structure, dependencies, or code in this base project to suit your needs. This will be the project skeleton that others will use when generating a new project from your archetype.
Step 2: Create an Archetype from the Existing Project
Once you have a base project ready, you can convert it into a Maven archetype. Run the following command in the directory of the project you want to use as the template:
1
mvn archetype:create-from-project
This will generate an archetype based on the structure of your current project. After running the command, 
Maven creates the archetype in the target/generated-sources/archetype directory.
Step 3: Install the Archetype Locally
To make the archetype available in your local Maven repository, navigate to the archetype directory and run:
1
2
cd target/generated-sources/archetype
mvn install
This installs the archetype in your local repository so that you can use it when generating new projects.
Step 4: Use the Custom Archetype
Once your custom archetype is installed, you can use it to generate new projects. Use the following command:
1
mvn archetype:generate -DarchetypeGroupId=com.example -DarchetypeArtifactId=my-app-archetype -DarchetypeVersion=1.0-SNAPSHOT -DgroupId=com.example.project -DartifactId=new-project
Replace archetypeGroupId, archetypeArtifactId, and archetypeVersion with the values of your custom archetype.
Step 5: Distribute the Archetype
To share the archetype with others, you have two main options:
- 
    Deploy to a Remote Repository: 
 You can deploy your archetype to a remote Maven repository like Nexus or Artifactory, allowing others to use it by adding the repository to their Maven settings.Run the following command to deploy your archetype: 1 mvn deploy 
- 
    Share as a ZIP or Git Repository: You can also package the archetype as a ZIP file or share it via a Git repository, where other users can download it and install it in their local Maven repositories. 
Step 6: Customizing Your Archetype (Optional)
You can customize the generated archetype by modifying the archetype-metadata.xml file located 
in the src/main/resources/META-INF/maven directory. This file defines which files and directories 
should be included in the archetype and how placeholders (like ${groupId} or ${artifactId}) 
should be replaced during project generation.
Here’s an example of what archetype-metadata.xml might look like:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<archetype-descriptor name="my-app-archetype">
  <requiredProperties>
    <requiredProperty key="groupId"/>
    <requiredProperty key="artifactId"/>
  </requiredProperties>
  <fileSets>
    <fileSet>
      <directory>src/main/java</directory>
      <includes>
        <include>**/*.java</include>
      </includes>
    </fileSet>
    <fileSet>
      <directory>src/test/java</directory>
      <includes>
        <include>**/*.java</include>
      </includes>
    </fileSet>
  </fileSets>
</archetype-descriptor>
Step 7: Testing the Archetype
It’s a good practice to test your archetype to ensure it works as expected. You can use the archetype directly from your local Maven repository to generate new projects and verify that everything (structure, placeholders, configurations) is functioning correctly.
1
mvn archetype:generate -DarchetypeGroupId=com.example -DarchetypeArtifactId=my-app-archetype -DarchetypeVersion=1.0-SNAPSHOT -DgroupId=com.example.test -DartifactId=test-project
Conclusion
By following these steps, you can create a custom Maven archetype tailored to your organization’s needs, saving time and ensuring consistent project structure across teams. Custom archetypes are a powerful way to automate project setup and embed best practices directly into the template.
With a bit of customization in archetype-metadata.xml, you can make your archetype even more flexible and 
feature-rich, allowing developers to kick-start new projects with minimal effort.