maven多工程构建与打包

目标:webapp_aggregator为聚合和父pom工程,不包含代码和资源,webapp为主web工程,webapp_module1为子web工程,webapp_common为基础子工程,两个web工程都依赖该工程。打包后webapp和webapp_module1合并为1个war包webapp.war,并且自动发布到tomcat,支持断点调试。

依赖关系:webapp->webapp_module1; webapp->webapp_common; webapp_module1->webapp_common。

1,eclipse新建maven quickstart工程webapp_aggregator和webapp_common, 新建maven web工程webapp和webapp_module1,每个工程点击properties->java build path, properties->java compiler保证选择了正确的jdk版本(如果是jre版本编译时会出错,需要点击windows->preferences->java->installed jres,改为jdk的目录),点击properties->project facets,选择正确的java版本,如果是web工程,需要选择dynamic web module的版本和runtimes(apache tomcat v8.0)。

2,webapp_aggragator工程pom.xml:

<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>
<name>webapp_aggregator</name>
<url>http://maven.apache.org</url> <groupId>com.xf</groupId>
<artifactId>webapp_aggregator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- 该工程为java工程,此工程只是作为聚合和父工程,打包类型为pom,其它子工程继承该工程的pom,包括相关的依赖 -->
<packaging>pom</packaging> <!-- 通过modules标签聚合3个子工程,依赖关系为webapp->webapp_module,这两个工程为web工程,同时这两个工程都依赖webapp_common工程,webapp_common工程为java工程 -->
<modules>
<!-- 父工程和子工程在同一个工作空间下,所以用相对路径即可 -->
<module>../webapp</module>
<module>../webapp_module1</module>
<module>../webapp_common</module>
</modules> <properties>
<!-- 指定工程编译后的编码格式为UTF-8,默认是GBK,所以要指定后才是UTF-8 -->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> <build>
<plugins>
<!-- 该插件可解决maven update后jre变为1.5的问题 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build> <!-- 以下依赖都会被子工程继承 -->
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-json-plugin</artifactId>
<version>2.3.20</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.3.7.Final</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.0.3</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.0.3</version>
</dependency>
</dependencies>
</project>

3,webapp工程pom.xml:

<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/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion>
<url>http://maven.apache.org</url>
<name>webapp Maven Webapp</name> <artifactId>webapp</artifactId>
<!-- web工程打包类型为war -->
<packaging>war</packaging> <!-- 继承webapp_aggregator的pom配置 -->
<parent>
<groupId>com.xf</groupId>
<artifactId>webapp_aggregator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath>../webapp_aggregator</relativePath>
</parent> <build>
<!-- 打包后target目录下的工程名称 -->
<finalName>webapp</finalName>
<plugins>
<!-- 该插件用于合并多个web工程为一个war,该插件只需要在主工程中配置即可,此处主工程为webapp,子工程为webapp_module1 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.6</version>
<configuration>
<!-- 必须配置此项,否则打包后的web.xml可能是某个子工程的,该配置用于排除打包overlays标签中配置的工程的web.xml,对所有overlays标签中的工程有效 -->
<packagingExcludes>WEB-INF/web.xml</packagingExcludes>
<overlays>
<overlay>
<groupId>com.xf</groupId>
<artifactId>webapp_module1</artifactId>
</overlay>
<!-- 如果overlay中什么都不写,表示该overlay代表的是当前工程,即当前pom.xml所在的工程webapp,一般情况下不要加入当前工程
<overlay>
</overlay>
-->
</overlays>
</configuration>
</plugin> <!-- 该插件用于将工程发布到tomcat,tomcat需要处于运行状态,另外如果是多web工程聚合项目,主工程和所有依赖的子工程都要配置该插件,否则发布的时候会报错 -->
<!-- 相关的maven发布命令为 tomcat:redeploy 或 tomcat:deploy -->
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>tomcat-maven-plugin</artifactId>
<version>1.1</version>
<configuration>
<!-- 此处为固定配置 适用于tomcat8 -->
<url>http://localhost:8080/manager/text</url>
<!-- 此处的myTomcat对应Apache maven安装目录的conf/setting.xml中的server配置
<servers>
<server>
<id>myTomcat</id>
<username>tomcat</username>
<password>tomcat</password>
</server>
</servers>
另外要注意,tomcat8 server的tomcat-users.xml中配置的role一定要加上manager-script角色,否则会发布失败,标准写法为
<role rolename="manager-gui"/>
<role rolename="manager-script"/>
<user password="tomcat" roles="manager-gui,manager-script" username="tomcat"/>
在eclipse创建的Servers的tomcat-users.xml中更改即可,启动后会自动同步到tomcat安装目录的tomcat-users.xml
-->
<server>myTomcat</server>
<!-- 配置该项后发布到tomcat webapps目录下的war包为webapp.war,如果不设置会默认生成ROOT.war -->
<path>/webapp</path>
</configuration>
</plugin>
</plugins>
</build> <!-- 当前项目需要的依赖,注意由于继承了webapp_aggregator工程的pom.xml,所以webapp_aggregator中已有的依赖不需要再重新配置 -->
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<!-- 如果版本是3.1,前面必须加javax前缀 -->
<artifactId>javax.servlet-api</artifactId>
<!-- 此处的版本必须小于等于当前工程(webapp)->properties->project facets->dynamic web module->version的版本号,否则编译会报错 -->
<!-- 如果project facets中的dynamic web module的version无法更改到3.1,那么需要更改几处地方:
1,当前工程的web.xml的正确标准模板为:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1" xmlns="http://xmlns.jcp.org/xml/ns/javaee">
</web-app>
2,依赖jdk为1.7或以上
3,maven插件最好都为最新版
4,当前工程.settings/org.eclipse.wst.common.project.facet.core.xml中的jst.web的version更改为3.1 <installed facet="jst.web" version="3.1"/>
5,运行maven update后即可
-->
<version>3.1.0</version>
<!-- 因为运行时该jar包在tomcat中已经存在,所以不需要打包该jar,用provide scope即可 -->
<scope>provided</scope>
</dependency>
<!-- 依赖webapp_common工程 -->
<dependency>
<groupId>com.xf</groupId>
<artifactId>webapp_common</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<!-- 依赖webapp_module1工程,因为要合并到主工程war包中,所以type为war -->
<dependency>
<groupId>com.xf</groupId>
<artifactId>webapp_module1</artifactId>
<version>0.0.1-SNAPSHOT</version>
<type>war</type>
</dependency>
</dependencies>
</project>

4,webapp_module1工程pom.xml:

<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/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion>
<name>webapp_module1 Maven Webapp</name>
<url>http://maven.apache.org</url> <artifactId>webapp_module1</artifactId>
<!-- web工程打包类型为war -->
<packaging>war</packaging> <!-- 继承webapp_aggregator的pom配置 -->
<parent>
<groupId>com.xf</groupId>
<artifactId>webapp_aggregator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath>../webapp_aggregator</relativePath>
</parent> <build>
<!-- 打包后target目录下的工程名称 -->
<finalName>webapp_module1</finalName>
<plugins>
<!-- 该插件用于将工程发布到tomcat,tomcat需要处于运行状态,另外如果是多web工程聚合项目,主工程和所有依赖的子工程都要配置该插件,否则发布的时候会报错 -->
<!-- 相关的maven发布命令为 tomcat:redeploy 或 tomcat:deploy -->
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>tomcat-maven-plugin</artifactId>
<version>1.1</version>
<configuration>
<!-- 此处为固定配置 适用于tomcat8 -->
<url>http://localhost:8080/manager/text</url>
<!-- 此处的myTomcat对应Apache maven安装目录的conf/setting.xml中的server配置
<servers>
<server>
<id>myTomcat</id>
<username>tomcat</username>
<password>tomcat</password>
</server>
</servers>
另外要注意,tomcat8 server的tomcat-users.xml中配置的role一定要加上manager-script角色,否则会发布失败,标准写法为
<role rolename="manager-gui"/>
<role rolename="manager-script"/>
<user password="tomcat" roles="manager-gui,manager-script" username="tomcat"/>
在eclipse创建的Servers的tomcat-users.xml中更改即可,启动后会自动同步到tomcat安装目录的tomcat-users.xml
-->
<server>myTomcat</server>
<!-- 配置该项后发布到tomcat webapps目录下的war包为webapp.war,如果不设置会默认生成ROOT.war -->
<path>/webapp</path>
</configuration>
</plugin>
</plugins>
</build> <!-- 当前项目需要的依赖,注意由于继承了webapp_aggregator工程的pom.xml,所以webapp_aggregator中已有的依赖不需要再重新配置 -->
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<!-- 如果版本是3.1,前面必须加javax前缀 -->
<artifactId>javax.servlet-api</artifactId>
<!-- 此处的版本必须小于等于当前工程(webapp)->properties->project facets->dynamic web module->version的版本号,否则编译会报错 -->
<!-- 如果project facets中的dynamic web module的version无法更改到3.1,那么需要更改几处地方:
1,当前工程的web.xml的正确标准模板为:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1" xmlns="http://xmlns.jcp.org/xml/ns/javaee">
</web-app>
2,依赖jdk为1.7或以上
3,maven插件最好都为最新版
4,当前工程.settings/org.eclipse.wst.common.project.facet.core.xml中的jst.web的version更改为3.1 <installed facet="jst.web" version="3.1"/>
5,运行maven update后即可
-->
<version>3.1.0</version>
<!-- 因为运行时该jar包在tomcat中已经存在,所以不需要打包该jar,用provide scope即可 -->
<scope>provided</scope>
</dependency>
<!-- 依赖webapp_common工程 -->
<dependency>
<groupId>com.xf</groupId>
<artifactId>webapp_common</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
</project>

5,webapp_common工程pom.xml:

<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>
<name>webapp_common</name>
<url>http://maven.apache.org</url> <artifactId>webapp_common</artifactId>
<!-- java普通工程,打包类型为jar -->
<packaging>jar</packaging> <!-- 继承webapp_aggregator的pom配置 -->
<parent>
<groupId>com.xf</groupId>
<artifactId>webapp_aggregator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath>../webapp_aggregator</relativePath>
</parent> <build>
<!-- 打包后target目录下的工程名称 -->
<finalName>webapp_common</finalName>
</build>
</project>

5,eclipse下加入debug需要的source,点击debug configurations->apache tomcat->tomcat v8.0 at localhost->source->add,将相关的工程source添加进来,点击debug按钮启动tomcat。

6,点击debug configurations->maven build->webapp_aggregator(如果没有需要new一个),basedirectory选择webapp_aggregator所在的目录,goals中填写clean package tomcat:redeploy -e,-e参数表示打印异常。点击debug按钮即可完成编译、打包和发布到tomcat。

ps:每次pom.xml更改后,运行maven update命令更新一下。

上一篇:Logstash:实用 Logstash 收集 Syslog 日志指南


下一篇:5分钟弄懂Docker--转载