
本文共 7277 字,大约阅读时间需要 24 分钟。
Maven私服构建与插件开发
一、maven生命周期
知识点概要:
- 生命周期的概念与意义
- maven三大生命周期与其对应的phase(阶段)
- 生命周期与插件的关系
- 生命周期与默认插件的绑定
1、生命周期的概念与意义
在项目构建时通常会包含清理、编译、测试、打包、验证、部署、文档生成等步骤,maven统一对其进行了整理抽象成三个生命周期(ilfecycle)及各自对应的多个阶段(phase)。这么做的意义是:
- 每一个阶段都成为一个扩展点,可以采用不同的方式来实现,提高了扩展性与灵活性。
- 规范统一了maven的执行路径。
在执行项目构建阶段是可以采用jar方式构建也可以采用war包方式构建提高了灵活性。我们可以通过mvn$(phase name)直接触发指定阶段的执行如:
演示phase的执行
#执行清理phasemvn clean#执行compile phasemvn compile#也可以同时执行 清理加编译mvn clean comile
2、maven三大生命周期与对应的phase(阶段)
maven 总共包含三大生生命周期
-
clean Lifecycle :清理生命周期,用于于清理项目
-
default Lifecycle:默认生命周期,用于编译、打包、测试、部署等
-
site Lifecycle 站点文档生成,用于构建站点文档
clean Lifecycle
#阶段(phase)pre-clean #预清理clean #清理post-clean #清理之后
default Lifecycle
#阶段(phase)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
#阶段(phase)pre-site #准备构建站点site #构建站点post-site #构建站点之后site-deploy #站点部署
在生命周期里,是有严格执行的顺序的,比如你要执行pakcage阶段前必须是先执行完compile先,当你没有compile直接pakcage,在pakcage前面的阶段会自动执行
小案例
# 执行编译mvn compile# 执行打包mvn package# 清理项目mvn clean# 直接执行打包就包含了编译指令的执行mvn package
通过上面案例会发现我不执行compile阶段直接执行package阶段我的项目仍然可以进行打包,因为在我们执行package阶段前maven自动执行了在package阶段前需要执行的全部阶段
3、生命周期与插件的关系
什么是插件?当我们执行mvn compile或者mvn package这些阶段时是如何实现的呢?这些阶段谁来实现呢?这就是插件,maven的核心代码其实很少,大部分实现都是由插件来完成的。
https://maven.apache.org/ref/3.6.2/maven-core/lifecycles.html 我们可以去maven官网看看每一个阶段的插件
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Qo0OU0e4-1574345407762)(E:\架构师\git与svn原理截图\image-20191120213252397.png)]
这是我们用的clean命令其实他是由 org.apache.maven.plugins:maven-clean-plugin:2.5:clean 插件实现的
这是我们用的打包jar命令我们可以发现这里面用到了不止一个插件,从中我们可以得出一个阶段可以使用多个插件,当我们执行packege时插件会从上往下依次执行到packege
总结:
生命周期的阶段可以绑定具体的插件及目标
同一个阶段可以对应多个插件和目标
phase(阶段)》plugin(插件)》goal(实现)
4、生命周期与插件的默认绑定
既然执行每一个阶段需要插件,为什么我们不用配置任何插件就可以执行了呢,其实maven都有一些默认的绑定插件我们
就拿clean来举例子,clean中有3个命令 pre-clean clean post-clean我们可以看到这3个命令只有clean绑定了插件所以只有clean是有用的 pre-clean命令其实是没反应的,但是没有任何插件绑定的post-clean执行之后会有反应呢,因为每一个阶段是生命周期都是严格按照顺序执行的在执行post-clean之前许先执行pre-clean和clean所以执行post-clean就会把项目clean
那么这些插件配置在哪里呢?
apache-maven-3.6.1\maven-core-3.6.1.jar\lib\META-INF\plexus\default-bindings.xml
二、maven自定义插件开发
知识点:
- 插件的相关概念
- 常用插件的使用
- 开发一个自定义插件
1、maven插件相关概念
插件坐标定位:
插件和普通jar包一样包含 一组坐标定位属性
groupId、artifactId、version,当使用该插件时会从本地仓库中搜索,如果没有即从远程仓库下载
org.apache.maven.plugins maven-dependency-plugin 2.10
插件执行 execution:
execution 配置包含一组指示插件如何执行的属性:
id : 执行器命名
phase:在什么阶段执行?
goals:执行一组什么目标或功能?
configuration:执行目标所需的配置文件?
小案例
org.apache.maven.plugins maven-dependency-plugin 3.1.1 copy-dep package copy-dependencies ${project.build.directory}/alternateLocation false true true
2、常用插件的使用
除了通过配置的方式使用插件以外,Maven也提供了通过命令直接调用插件目标其命令格式如下:
mvn groupId:artifactId:version:goal -D{ 参数名}
如果使用maven原生的插件则可以简化书写
# 展示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=xxx -DartifactId=xxx -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false#快速创建一个java 项目mvn archetype:generate -DgroupId=xxx -DartifactId=xxx -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false
3、开发自定义插件
实现步骤:
-
创建maven 插件项目
-
设定packaging 为maven-plugin
-
添加插件依赖
-
编写插件实现逻辑
-
打包构建插件
4.0.0 lzj lzj-maven-plugin 1.0-SNAPSHOT maven-plugin org.apache.maven maven-plugin-api 3.0.3 org.apache.maven.plugin-tools maven-plugin-annotations 3.1
/** * @Author: LZJ * @Date: 2019/11/20 22:49 * @Version 1.0 */@Mojo(name = "lzj") //goal名称public class LuzjPlugin extends AbstractMojo { //继承AbstractMojo @Parameter //需要传入参数 String sex; @Parameter //需要传入参数 String describe; public void execute() throws MojoExecutionException, MojoFailureException { getLog().info(String.format("lzj sex=%s,describe=%s",sex,describe)); //打印 }}
运行install把插件 装入maven本地仓库
lzj lzj-maven-plugin 1.0-SNAPSHOT print-info compile lzj man good
三、nexus 私服搭建与核心功能
知识点概要:
-
私服的使用场景
-
nexus 下载安装
-
nexus 仓库介绍
-
本地远程仓库配置
-
发布项目至nexus 远程仓库
-
关于SNAPSHOT(快照)与RELEASE(释放) 版本说明
1、私服使用场景
私服使用场景如下:
-
公司不能连接公网,可以用一个私服务来统一连接
-
公司内部jar 组件的共享
nexus 下载安装
nexus 下载地址:
https://sonatype-download.global.ssl.fastly.net/nexus/oss/nexus-2.14.5-02-bundle.tar.gz
解压并配置环境变量
#解压tar -zxvf nexus-2.14.5-02-bundle.tar.gz#在环境变量当中设置启动用户vim /etc/profile#添加profile文件。安全起见不建议使用root用户,如果使用其它用户需要加相应权限export RUN_AS_USER=root#读取并执行source /etc/profile
配置启动参数
vi ${nexusBase}/conf/nexus.properties #端口号 application-port=9999启动与停止nexus#启动 ${nexusBase}/bin/nexus start#停止 ${nexusBase}/bin/nexus stop登录nexus 界面地址:http://{ ip}:9999/nexus/用户名:admin密码:admin123
3、仓库介绍
3rd party:第三方仓库
Apache Snapshots:apache 快照仓库
Central: maven 中央仓库
Releases:私有发布版本仓库
Snapshots:私有 快照版本仓库
4、本地远程仓库配置
nexus-public my nexus repository http://192.168.0.147:9999/nexus/content/groups/public/ nexus-aliyun * Nexus aliyun http://192.168.0.147:9999/nexus/content/groups/public/
5、发布项目至nexus 远程仓库
nexus-release nexus release http://192.168.0.147:9999/nexus/content/repositories/releases/ nexus-snapshot nexus snapshot http://192.168.0.147:9999/nexus/content/repositories/snapshots/ nexus-snapshot deployment deployment123 nexus-release deployment deployment123
执行deploy 命令
/snapshots/
nexus-snapshot deployment deployment123 nexus-release deployment deployment123执行deploy 命令mvn deploy
发表评论
最新留言
关于作者
