摘要:
Archetype是什么?它由哪些文件组成?如何创建和安装自己的archtype,如何使用自己创建的archetype?

一、Archetype是什么
Archetype其实就是一个Maven的Project模板,以方便用户快速创建maven的Project。有官方提供的Archetype,用户也可以创建自己的Archetype,比如我们公司的所有工程都使用相同的groupId,都将包含相同的库文件,那么我们就可以创建一个自己的archetype,然后大家下载过去安装在自己的本地。或者放在一个内部服务器上,然后大家在自己的eclipse上配置好该服务器catogries.xml文件的路径;
下图是官方提供的Archetype的生命周期,现在只要了解,后续将详细介绍。

二、Archetype工程的组成
http://maven.apache.org/guides/mini/guide-creating-archetypes.html 
一个典型的archetype包含如下组成部分:
1)Archetype descriptor(archetype.xml),这个文件位于路径src/main/resources/META-INF/maven/,那就除了所有将要包含在archetype中的文件,并且给他们做了分类以便Archetype的生成机制可以正确的处理它们;
2)Archetype插件将要拷贝的原型文件,位于路径,src/main/resources/archetype-resources/;
3)pom.xml原型文件,位于路径:src/main/resources/archetype-resources
4)这个工程本身自己的pom.xml;
三、如何生成Archetype
    首先基于一个用户已有的工程,使用mvn archetype:create-from-project 就可以在该project的target\generate-sources\archetype生成了一个archetype。

比如我刚刚在gs-rest-service-yang工程内运行了mvn archetype:create-from-project命令,然后在target子目录下声称了generated-sources文件夹,文件夹内包含了archetype文件夹,该文件夹的内容如下:
  1. │ pom.xml
  2. ├─src
  3. │ ├─main
  4. │ │ └─resources
  5. │ │ ├─archetype-resources
  6. │ │ │ │ .classpath
  7. │ │ │ │ .project
  8. │ │ │ │ pom.xml
  9. │ │ │ │
  10. │ │ │ ├─.settings
  11. │ │ │ │ org.eclipse.core.resources.prefs
  12. │ │ │ │ org.eclipse.jdt.core.prefs
  13. │ │ │ │ org.eclipse.m2e.core.prefs
  14. │ │ │ │
  15. │ │ │ └─src
  16. │ │ │ ├─main
  17. │ │ │ │ └─java
  18. │ │ │ │ Application.java
  19. │ │ │ │ Quote.java
  20. │ │ │ │ Value.java
  21. │ │ │ │
  22. │ │ │ └─test
  23. │ │ │ └─java
  24. │ │ │ AppTest.java
  25. │ │ │
  26. │ │ └─META-INF
  27. │ │ └─maven
  28. │ │ archetype-metadata.xml
  29. │ │
  30. │ └─test
  31. │ └─resources
  32. │ └─projects
  33. │ └─basic
  34. │ archetype.properties
  35. │ goal.txt
  36. └─target
  37. │ gs-rest-service-yang-archetype-0.0.1-SNAPSHOT.jar
  38. ├─classes
  39. │ ├─archetype-resources
  40. │ │ │ .classpath
  41. │ │ │ .project
  42. │ │ │ pom.xml
  43. │ │ │
  44. │ │ ├─.settings
  45. │ │ │ org.eclipse.core.resources.prefs
  46. │ │ │ org.eclipse.jdt.core.prefs
  47. │ │ │ org.eclipse.m2e.core.prefs
  48. │ │ │
  49. │ │ └─src
  50. │ │ ├─main
  51. │ │ │ └─java
  52. │ │ │ Application.java
  53. │ │ │ Quote.java
  54. │ │ │ Value.java
  55. │ │ │
  56. │ │ └─test
  57. │ │ └─java
  58. │ │ AppTest.java
  59. │ │
  60. │ └─META-INF
  61. │ └─maven
  62. │ archetype-metadata.xml
  63. ├─gs-rest-service-yang-archetype-0.0.1-SNAPSHOT
  64. │ ├─archetype-resources
  65. │ │ │ .classpath
  66. │ │ │ .project
  67. │ │ │ pom.xml
  68. │ │ │
  69. │ │ ├─.settings
  70. │ │ │ org.eclipse.core.resources.prefs
  71. │ │ │ org.eclipse.jdt.core.prefs
  72. │ │ │ org.eclipse.m2e.core.prefs
  73. │ │ │
  74. │ │ └─src
  75. │ │ ├─main
  76. │ │ │ └─java
  77. │ │ │ Application.java
  78. │ │ │ Quote.java
  79. │ │ │ Value.java
  80. │ │ │
  81. │ │ └─test
  82. │ │ └─java
  83. │ │ AppTest.java
  84. │ │
  85. │ └─META-INF
  86. │ └─maven
  87. │ archetype-metadata.xml
  88. └─test-classes
  89. └─projects
  90. └─basic
  91. archetype.properties
  92. goal.txt
可以看到上面有一些.setting, .class, .project的文件,这些是多余的。

所以我们在搭建好样板工程之后,在使用mvn archetype:create-from-project命令之前,要先把项目中不相关的工程文件、中间文件删除。
清除之后重新声称的结构如下:
  1. │ pom.xml
  2. ├─src
  3. │ ├─main
  4. │ │ └─resources
  5. │ │ ├─archetype-resources
  6. │ │ │ │ pom.xml
  7. │ │ │ │
  8. │ │ │ └─src
  9. │ │ │ ├─main
  10. │ │ │ │ └─java
  11. │ │ │ │ Application.java
  12. │ │ │ │ Quote.java
  13. │ │ │ │ Value.java
  14. │ │ │ │
  15. │ │ │ └─test
  16. │ │ │ └─java
  17. │ │ │ AppTest.java
  18. │ │ │
  19. │ │ └─META-INF
  20. │ │ └─maven
  21. │ │ archetype-metadata.xml
  22. │ │
  23. │ └─test
  24. │ └─resources
  25. │ └─projects
  26. │ └─basic
  27. │ archetype.properties
  28. │ goal.txt
  29. └─target
  30. │ gs-rest-service-yang-archetype-0.0.1-SNAPSHOT.jar
  31. ├─classes
  32. │ ├─archetype-resources
  33. │ │ │ pom.xml
  34. │ │ │
  35. │ │ └─src
  36. │ │ ├─main
  37. │ │ │ └─java
  38. │ │ │ Application.java
  39. │ │ │ Quote.java
  40. │ │ │ Value.java
  41. │ │ │
  42. │ │ └─test
  43. │ │ └─java
  44. │ │ AppTest.java
  45. │ │
  46. │ └─META-INF
  47. │ └─maven
  48. │ archetype-metadata.xml
  49. └─test-classes
  50. └─projects
  51. └─basic
  52. archetype.properties
  53. goal.txt
四、生成Archetype如何安装
在上文创建了archetype之后,进入到target\generate-sources\archetype目录,然后在命令行执行:
mvn install
则输出如下信息,特别是installing这段,表示就安装成功了。
  1. [INFO] Scanning for projects...
  2. [INFO]
  3. [INFO] ------------------------------------------------------------------------
  4. [INFO] Building gs-rest-service-yang-archetype 0.0.1-SNAPSHOT
  5. [INFO] ------------------------------------------------------------------------
  6. [INFO]
  7. [INFO] --- maven-resources-plugin:3.0.2:resources (default-resources) @ gs-rest-service-yang-archetype ---
  8. [WARNING] Using platform encoding (GBK actually) to copy filtered resources, i.e. build is platform dependent!
  9. [INFO] Copying 6 resources
  10. [INFO]
  11. [INFO] --- maven-resources-plugin:3.0.2:testResources (default-testResources) @ gs-rest-service-yang-archetype ---
  12. [WARNING] Using platform encoding (GBK actually) to copy filtered resources, i.e. build is platform dependent!
  13. [INFO] Copying 2 resources
  14. [INFO]
  15. [INFO] --- maven-archetype-plugin:3.0.0:jar (default-jar) @ gs-rest-service-yang-archetype ---
  16. [INFO] Building archetype jar: D:\WORK\personal\2.src\3.spring\gs-rest-service-yang-2\target\generated-sources\archetype
  17. \target\gs-rest-service-yang-archetype-0.0.1-SNAPSHOT
  18. [INFO]
  19. [INFO] --- maven-archetype-plugin:3.0.0:integration-test (default-integration-test) @ gs-rest-service-yang-archetype ---
  20. [INFO] Processing Archetype IT project: basic
  21. [INFO] ----------------------------------------------------------------------------
  22. [INFO] Using following parameters for creating project from Archetype: gs-rest-service-yang-archetype:0.0.1-SNAPSHOT
  23. [INFO] ----------------------------------------------------------------------------
  24. [INFO] Parameter: groupId, Value: archetype.it
  25. [INFO] Parameter: artifactId, Value: basic
  26. [INFO] Parameter: version, Value: 0.1-SNAPSHOT
  27. [INFO] Parameter: package, Value: it.pkg
  28. [INFO] Parameter: packageInPathFormat, Value: it/pkg
  29. [INFO] Parameter: version, Value: 0.1-SNAPSHOT
  30. [INFO] Parameter: package, Value: it.pkg
  31. [INFO] Parameter: groupId, Value: archetype.it
  32. [INFO] Parameter: artifactId, Value: basic
  33. [INFO] Project created from Archetype in dir: D:\WORK\personal\2.src\3.spring\gs-rest-service-yang-2\target\generated-so
  34. urces\archetype\target\test-classes\projects\basic\project\basic
  35. [INFO]
  36. [INFO] --- maven-install-plugin:2.5.2:install (default-install) @ gs-rest-service-yang-archetype ---
  37. [INFO] Installing D:\WORK\personal\2.src\3.spring\gs-rest-service-yang-2\target\generated-sources\archetype\target\gs-re
  38. st-service-yang-archetype-0.0.1-SNAPSHOT.jar to C:\Users\yangg\.m2\repository\com\huajiesolar\gs-rest-service-yang-arche
  39. type\0.0.1-SNAPSHOT\gs-rest-service-yang-archetype-0.0.1-SNAPSHOT.jar
  40. [INFO] Installing D:\WORK\personal\2.src\3.spring\gs-rest-service-yang-2\target\generated-sources\archetype\pom.xml to C
  41. :\Users\yangg\.m2\repository\com\huajiesolar\gs-rest-service-yang-archetype\0.0.1-SNAPSHOT\gs-rest-service-yang-archetyp
  42. e-0.0.1-SNAPSHOT.pom
  43. [INFO]
  44. [INFO] --- maven-archetype-plugin:3.0.0:update-local-catalog (default-update-local-catalog) @ gs-rest-service-yang-arche
  45. type ---
  46. [INFO] ------------------------------------------------------------------------
  47. [INFO] BUILD SUCCESS
  48. [INFO] ------------------------------------------------------------------------
  49. [INFO] Total time: 2.073 s
  50. [INFO] Finished at: 2017-02-21T22:35:47+08:00
  51. [INFO] Final Memory: 14M/153M
  52. [INFO] ------------------------------------------------------------------------
安装之后主要做了两件事情:
1) 将文件安装到mvn缓存目录,在我本机就是C:\Users\yangg\.m2\repository\com\huajiesolar\gs-rest-service-yang-archetype,该文件夹下的目录结构如下:
  1. | maven-metadata-local.xml
  2. |
  3. \---0.0.1-SNAPSHOT
  4. gs-rest-service-yang-archetype-0.0.1-SNAPSHOT.jar
  5. gs-rest-service-yang-archetype-0.0.1-SNAPSHOT.pom
  6. maven-metadata-local.xml
  7. _remote.repositories
2)创建了文件 C:\Users\yangg\.m2\repository\archetype-catalog.xml文件,文件内容如下:
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <archetype-catalog xsi:schemaLocation="http://maven.apache.org/plugins/maven-archetype-plugin/archetype-catalog/1.0.0 http://maven.apache.org/xsd/archetype-catalog-1.0.0.xsd"
  3. xmlns="http://maven.apache.org/plugins/maven-archetype-plugin/archetype-catalog/1.0.0"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  5. <archetypes>
  6. <archetype>
  7. <groupId>com.huajiesolar</groupId>
  8. <artifactId>gs-rest-service-yang-archetype</artifactId>
  9. <version>0.0.1-SNAPSHOT</version>
  10. <description>Parent pom providing dependency and plugin management for applications
  11. built with Maven</description>
  12. </archetype>
  13. </archetypes>
  14. </archetype-catalog>
五、使用上文创建的archetype
有2种使用方式:
1)通过命令行使用
找到一个空目录,然后执行如下命令:
mvn archetype:generate -DarchetypeCatalog=local
此时会给出上文安装的archetype,选择即可,如下:
  1. [INFO] Scanning for projects...
  2. [INFO]
  3. [INFO] ------------------------------------------------------------------------
  4. [INFO] Building Maven Stub Project (No POM) 1
  5. [INFO] ------------------------------------------------------------------------
  6. [INFO]
  7. [INFO] >>> maven-archetype-plugin:3.0.0:generate (default-cli) > generate-sources @ standalone-pom >>>
  8. [INFO]
  9. [INFO] <<< maven-archetype-plugin:3.0.0:generate (default-cli) < generate-sources @ standalone-pom <<<
  10. [INFO]
  11. [INFO] --- maven-archetype-plugin:3.0.0:generate (default-cli) @ standalone-pom ---
  12. [INFO] Generating project in Interactive mode
  13. [INFO] No archetype defined. Using maven-archetype-quickstart (org.apache.maven.archetypes:maven-archetype-quickstart:1.0)
  14. Choose archetype:
  15. 1: local -> com.huajiesolar:gs-rest-service-yang-archetype (Parent pom providing dependency and plugin management for applications
  16. built with Maven)
  17. Choose a number or apply filter (format: [groupId:]artifactId, case sensitive contains): :
2)通过eclipse使用

因为C:\Users\yangg\.m2\repository\archetype-catalog.xml是新创建的,所以需要在ecliplse的 file -》new-》maven projects对话框中,在选择archetype页面上,如下图

点击上文的config按钮,弹出如下界面:

点击add local catalog ...按钮,在弹出的对话框中选择上文新声称的catalog文件:

点击Ok即可。

然后在界面上就可以选择新创建的archetype模板了。

附录:参考资料:   
http://maven.apache.org/guides/introduction/introduction-to-archetypes.html 
http://maven.apache.org/archetype/maven-archetype-plugin/index.html
http://maven.apache.org/archetype/maven-archetype-plugin/usage.html  
http://maven.apache.org/guides/mini/guide-creating-archetypes.html 
http://maven.apache.org/archetype/maven-archetype-plugin/create-from-project-mojo.html  

《Maven实战》

学习笔记:Maven的ArcheType的学习笔记相关推荐

  1. Maven项目依赖管理 学习笔记

    本学习笔记根据慕课视频[Maven项目依赖管理]摘录,主要学习maven的使用方式,从理念到实践.基础到应用,掌握基于maven管理java项目的方式. 目录 第一章 Maven概述 Maven简介 ...

  2. 《Java学习笔记(第8版)》学习指导

    <Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...

  3. Android初级开发笔记-- activity启动模式的学习(1)

    第一次学习Android中一个很重要的概念,启动模式.文章记录的也只是一些入门知识,随着学习的深入还会有activity启动模式的学习(2)和(3). 下面分三个小点说一下对启动模式的理解区别以及如何 ...

  4. 深度学习(DL)与卷积神经网络(CNN)学习笔记随笔-04-基于Python的LeNet之MLP

    原文地址可以查看更多信息 本文主要参考于:Multilayer Perceptron  python源代码(github下载 CSDN免费下载) 本文主要介绍含有单隐层的MLP的建模及实现.建议在阅读 ...

  5. 深度学习(DL)与卷积神经网络(CNN)学习笔记随笔-03-基于Python的LeNet之LR

    原地址可以查看更多信息 本文主要参考于:Classifying MNIST digits using Logistic Regression  python源代码(GitHub下载 CSDN免费下载) ...

  6. 学习鸟哥的Linux私房菜笔记(1)——Linux系统入门

    转载自: 专栏:鸟哥的Linux私房菜笔记 - 博客频道 - CSDN.NET http://blog.csdn.net/column/details/dawanganban-linux-n.html ...

  7. 机器学习处理信号分离_[学习笔记]使用机器学习和深度学习处理信号基础知识...

    参考学习:Signal Generation and Preprocessing 本人只是为了了解信号处理的基础知识而做的学习笔记,涉及深度可能不够,有理解错误的地方请大胆指出,感激不尽 一.信号生成 ...

  8. Coursera吴恩达《优化深度神经网络》课程笔记(1)-- 深度学习的实用层面

    红色石头的个人网站:redstonewill.com Andrew Ng的深度学习专项课程的第一门课<Neural Networks and Deep Learning>的5份笔记我已经整 ...

  9. Vue学习(slot、axios)-学习笔记

    文章目录 Vue学习(slot.axios)-学习笔记 slot 插槽 axios 交互 Vue学习(slot.axios)-学习笔记 slot 插槽 父: <template> < ...

最新文章

  1. 2018年8月以太坊DApp数据分析报告
  2. 致力云安全服务模式 安全狗获近5000万融资
  3. 查看Eclipse32位还是64位以及Eclipse的编译版本号,查看JDK是32位还是64位
  4. IT应聘者的简历应该是怎么样的?
  5. Excel催化剂开源第37波-音视频文件元数据提取(分辨率,时长,采样率等)
  6. oracle客户端三种连接,客户端连接ORACLE的几种方法
  7. sqlserver 导入mysql,在项目中迁移MS SQLServer到Mysql数据库,实现MySQL数据库的快速整合...
  8. mysql in操作_MySQL查询in操作排序
  9. ITIL 4讲解: 变更管理
  10. MPI 初认识 (入门教程)
  11. 基于PLC的智能化配电箱系统
  12. html绘制平滑等值面,前端基于Canvas生成等值面的方案
  13. 封装组件引发的问题——vue给对象添加响应式属性
  14. 回溯法-符号三角形问题
  15. windows输入法第一次输入的时候有时候不给我中文提示
  16. Linux下自动化运维工具ansible
  17. 一个人瘦到什么程度身材才算好?其实身材好与体重关系不大
  18. 液晶LCD1602驱动代码
  19. OpenGL---GLUT教程(一) GLUT简介,体系
  20. Ubuntu系统中编写c语言程序教程

热门文章

  1. 改变this指向的操作
  2. 18.3/18.4/18.5 用keepalived配置高可用集群
  3. keepalive高可用软件配置及详解
  4. JS——红包雨(抢红包)
  5. nodejs使用superagent写爬虫dns超时
  6. php for循环逗号,关于php:从foreach循环中删除最后一个逗号
  7. log4j简单配置总结
  8. 第十九篇:JAVA加密解密之RSA算法
  9. 2023 Hulu/Disney Streaming与广告北京研发中心秋季校园招聘开始啦!
  10. MySQL库迁移到达梦的过程中,出现列长度超出定义的问题导致中断