Introduction to Archetypes

What is Archetype?

In short, Archetype is a Maven project templating toolkit. An archetype is defined as an original pattern or model from which all other things of the same kind are made. The names fits as we are trying to provide a system that provides a consistent means of generating Maven projects. Archetype will help authors create Maven project templates for users, and provides users with the means to generate parameterized versions of those project templates.

Using archetypes provides a great way to enable developers quickly in a way consistent with best practices employed by your project or organization. Within the Maven project we use archetypes to try and get our users up and running as quickly as possible by providing a sample project that demonstrates many of the features of Maven while introducing new users to the best practices employed by Maven. In a matter of seconds a new user can have a working Maven project to use as a jumping board for investigating more of the features in Maven. We have also tried to make the Archetype mechanism additive and by that we mean allowing portions of a project to be captured in an archetype so that pieces or aspects of a project can be added to existing projects. A good example of this is the Maven site archetype. If, for example, you have used the quick start archetype to generate a working project you can then quickly create a site for that project by using the site archetype within that existing project. You can do anything like this with archetypes.

You may want to standardize J2EE development within your organization so you may want to provide archetypes for EJBs, or WARs, or for your web services. Once these archetypes are created and deployed in your organization's repository they are available for use by all developers within your organization.

Using an Archetype

To create a new project based on an Archetype, you need to call mvn archetype:generate goal, like the following:

mvn archetype:generate

Please refer to Archetype Plugin Page.

Provided Archetypes

Maven provides several Archetype artifacts:

Archetype ArtifactIdsDescription
maven-archetype-archetypeAn archetype which contains a sample archetype.
maven-archetype-j2ee-simpleAn archetype which contains a simplifed sample J2EE application.
maven-archetype-mojoAn archetype which contains a sample a sample Maven plugin.
maven-archetype-pluginAn archetype which contains a sample Maven plugin.
maven-archetype-plugin-siteAn archetype which contains a sample Maven plugin site.
maven-archetype-portletAn archetype which contains a sample JSR-268 Portlet.
maven-archetype-quickstartAn archetype which contains a sample Maven project.
maven-archetype-simpleAn archetype which contains a simple Maven project.
maven-archetype-siteAn archetype which contains a sample Maven site which demonstrates some of the supported document types like APT, XDoc, and FML and demonstrates how to i18n your site.
maven-archetype-site-simpleAn archetype which contains a sample Maven site.
maven-archetype-webappAn archetype which contains a sample Maven Webapp project.

For more information on these archetypes, please refer the Maven Archetypes page.

What makes up an Archetype?

Archetypes are packaged up in a JAR and they consist of the archetype metadata which describes the contents of archetype and a set of Velocity templates which make up the prototype project. If you would like to know how to make your own archetypes please refer to our Guide to creating archetypes.