第四课:Maven私服构建与插件开发.docx
一、maven 生命周期
知识点概要:
- 生命周期的概念与意义
- maven 三大生命周期与其对应的phase(阶段)
- 生命周期与插件的关系
- 生命周期与默认插件的绑定
1、生命周期的概念与意义
在项目构建时通常会包含清理、编译、测试、打包、验证、部署,文档生成等步骤,maven 统一对其进行了整理抽像成三个生命周期 (lifecycle)及各自对应的多个阶段(phase)。这么做的意义是:
- 每个阶段都成为了一个扩展点,可以采用不同的方式来实现,提高了扩展性与灵活性。
- 规范统一了maven 的执行路径。
在执行项目构建阶段时可以采用jar方式构建也可以采用war包方式构建提高了灵活性。我们可以通过命令 mvn ${phase name}直接触发指定阶段的执行如:
l 演示 phase 的执行
#执行清理phase
mvn clean
#执行compile phase
mvn compile
# 也可以同时执行 清理加编译
mvn clean compile
2、maven三大生命周期与其对应的phase(阶段)
maven 总共包含三大生生命周期
- clean Lifecycle :清理生命周期,用于清理项目
- default Lifecycle:默认生命周期,用于编译、打包、测试、部署等
- site Lifecycle 站点文档生成,用于构建站点文档
生命周期(lifecycle) |
阶段(phase) |
描述(describe) |
clean Lifecycle |
pre-clean |
预清理 |
clean |
清理 |
|
post-clean |
清理之后 |
|
default Lifecycle |
validate |
验证 |
initialize |
初始化 |
|
generate-sources |
|
|
process-sources |
|
|
generate-resources |
|
|
process-resources |
|
|
compile |
编译 |
|
process-classes |
|
|
generate-test-sources |
|
|
process-test-sources |
|
|
generate-test-resources |
|
|
process-test-resources |
|
|
test-compile |
编译测试类 |
|
process-test-classes |
|
|
test |
执行测试 |
|
prepare-package |
构建前准备 |
|
package |
打包构建 |
|
pre-integration-test |
|
|
integration-test |
|
|
post-integration-test |
|
|
verify |
验证 |
|
install |
上传到本地仓库 |
|
deploy |
上传到远程仓库 |
|
site Lifecycle |
pre-site |
准备构建站点 |
site |
构建站点 |
|
post-site |
构建站点之后 |
|
site-deploy |
站点部署 |
三大生命周期其相互独立执行,也可以合在一起执行。但lifecycle 中的phase 是有严格执行的顺序的,比如必须是先执行完compile 才能执行pakcage 动作,此外phase 还有包含逻辑存在,即当你执行一个phase 时 其前面的phase 会自动执行。
l 演示phase 执行
# 执行编译
mvn compile
# 执行打包就包含了编译指令的执行
mvn package
3、生命周期与插件的关系
生命周期的phase组成了项目过建的完整过程,但这些过程具体由谁来实现呢?这就是插件,maven 的核心部分代码量其实很少,其大部分实现都是由插件来完成的。比如:test 阶段就是由 maven-surefire-plugin 实现。在pom.xml 中我们可以设置指定插件目标(gogal)与phase 绑定,当项目构建到达指定phase时 就会触发些插件gogal 的执行。 一个插件有时会实现多个phase比如:maven-compiler-plugin插件分别实现了compile 和testCompile。
总结:
生命周期的 阶段 可以绑定具体的插件及目标
不同配置下同一个阶段可以对应多个插件和目标
phase==>plugin==>goal(功能)
4、生命周期与插件的默认绑定
在我们的项目当中并没有配置 maven-compiler-plugin 插件,但当我们执行compile 阶段时一样能够执行编译操作,原因是maven 默认为指定阶段绑定了插件实现。列如下以下两个操作在一定程度上是等价的。
#直接执行mvn命令
mvn compile
#直接执行compile插件目标
mvn org.apache.maven.plugins:maven-compiler-plugin:3.1:compile
lifecycle phase 的默认绑定见下表:。
注:不同的项目类型 其默认绑定是不同的,这里只指列举了packaging 为jar 的默认绑定,全部的默认绑定参见:https://maven.apache.org/ref/3.5.4/maven-core/default-bindings.html#
二、maven 自定义插件开发
知识点:
- 插件的相关概念
- 常用插件的使用
- 开发一个自定义插件
1、maven 插件相关概念
插件坐标定位:
插件与普通jar 包一样包含 一组件坐标定位属性即:
groupId、artifactId、version,当使用该插件时会从本地仓库中搜索,如果没有即从远程仓库下载
<!-- 唯一定位到dependency 插件 -->
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.10</version>
插件执行 execution:
execution 配置包含一组指示插件如何执行的属性:
id : 执行器命名
phase:在什么阶段执行?
goals:执行一组什么目标或功能?
configuration:执行目标所需的配置文件?
l 演示一个插件的配置与使用
# 将插件依赖拷贝到指定目录
# 将插件依赖拷贝到指定目录 <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>3.1.1</version> <executions> <execution> <id>copy-dependencies</id> <phase>package</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <outputDirectory>${project.build.directory}/alternateLocation</outputDirectory> <overWriteReleases>false</overWriteReleases> <overWriteSnapshots>true</overWriteSnapshots> <excludeTransitive>true</excludeTransitive> </configuration> </execution> </executions> </plugin>View Code
2、常用插件的使用
除了通过配置的方式使用插件以外,Maven也提供了通过命令直接调用插件目标其命令格式如下:
mvn groupId:artifactId:version:goal -D{参数名}
l 演示通过命令执行插件
# 展示pom的依赖关系树
mvn org.apache.maven.plugins:maven-dependency-plugin:2.10:tree
# 也可以直接简化版的命令,但前提必须是maven 官方插件
mvn dependency:tree
其它常用插件:
# 查看pom 文件的最终配置
mvn help:effective-pom
# 原型项目生成
archetype:generate
#快速创建一个WEB程序
mvn archetype:generate -DgroupId=tuling -DartifactId=simple-webbapp -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false
#快速创建一个java 项目
mvn archetype:generate -DgroupId=tuling -DartifactId=simple-java -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false
3、开发一个自定义插件
实现步骤:
n 创建maven 插件项目
n 设定packaging 为maven-plugin
n 添加插件依赖
n 编写插件实现逻辑
n 打包构建插件
插件 pom 配置:
<?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/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>tuling</groupId> <artifactId>tuling-maven-plugin</artifactId> <version>1.0-SNAPSHOT</version> <packaging>maven-plugin</packaging> <dependencies> <dependency> <groupId>org.apache.maven</groupId> <artifactId>maven-plugin-api</artifactId> <version>3.0.3</version> </dependency> <dependency> <groupId>org.apache.maven.plugin-tools</groupId> <artifactId>maven-plugin-annotations</artifactId> <version>3.1</version> </dependency> </dependencies> </project>View Code
插件实现类:
package com.tuling.plugin;/** * Created by Administrator on 2018/8/8. */ import org.apache.maven.plugin.AbstractMojo; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; import org.apache.maven.plugins.annotations.Mojo; import org.apache.maven.plugins.annotations.Parameter; /** * @author Tommy * Created by Tommy on 2018/8/8 **/ @Mojo(name = "luban") public class LubanPlugin extends AbstractMojo { @Parameter String sex; @Parameter String describe; public void execute() throws MojoExecutionException, MojoFailureException { getLog().info(String.format("luban sex=%s,describe=%s", sex, describe)); } }View Code
三、nexus 私服搭建与核心功能
知识点概要:
- 私服的使用场景
- nexus 下载安装
- nexus 仓库介绍
- 本地远程仓库配置
- 发布项目至nexus 远程仓库
- 关于SNAPSHOT(快照)与RELEASE(释放) 版本说明
3、nexus 仓库介绍
3rd party:第三方仓库
Apache Snapshots:apache 快照仓库
Central: maven *仓库
Releases:私有发布版本仓库
Snapshots:私有 快照版本仓库
4 、本地远程仓库配置
在pom.xml 中配置远程仓库
<repositories>
<repository>
<id>nexus-public</id>
<name>my nexus repository</name>
<url>http://192.168.0.147:9999/nexus/content/groups/public/</url>
</repository>
</repositories>
5、发布项目至nexus 远程仓库
配置仓库地址
<distributionManagement>
<repository>
<id>nexus-release</id>
<name>nexus release</name>
<url>http://192.168.0.147:9999/nexus/content/repositories/releases/</url>
</repository>
<snapshotRepository>
<id>nexus-snapshot</id>
<name>nexus snapshot</name>
<url>http://192.168.0.147:9999/nexus/content/repositories/snapshots/</url>
</snapshotRepository>
</distributionManagement>
- 在maven的设置 setting.xml 文件中配置server登录密码
<server>
<id>nexus-snapshot</id>
<username>deployment</username>
<password>deployment123</password>
</server>
<server>
<id>nexus-release</id>
<username>deployment</username>
<password>deployment123</password>
</server>
- 执行deploy 命令
mvn deploy
==============================================
参考资料: