idea maven assembly plugin 使用

 

安装监控中心:

1、dubbo官网源码下载 地址:https://github.com/apache/incubator-dubbo.git

2、cd  /${path}/dubbo-simple/dubbo-monitor-simple

mvn clean install -DskipTests=true  //win  需要配置maven

3、打包后的目录  进入target里面找到.   xxx.tar.gz  解压  解压后里面有bin  conf  lib   //windows无法解压tar.gz

4、将bin  conf 复制到项目中 

dubbo.properties配置


##
# Copyright 1999-2011 Alibaba Group.
#  
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#  
#      http://www.apache.org/licenses/LICENSE-2.0
#  
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
##
dubbo.container=log4j,spring,registry,jetty
dubbo.application.name=simple-monitor
dubbo.application.owner=
#dubbo.registry.address=multicast://224.5.6.7:1234
#配置zookeeper
dubbo.registry.address=zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183
#dubbo.registry.address=redis://127.0.0.1:6379
#dubbo.registry.address=dubbo://127.0.0.1:9090
dubbo.protocol.port=7070     
dubbo.jetty.port=9090
dubbo.jetty.directory=${user.home}/monitor
dubbo.charts.directory=${dubbo.jetty.directory}/charts
dubbo.statistics.directory=${user.home}/monitor/statistics
dubbo.log4j.file=logs/dubbo-monitor-simple.log
dubbo.log4j.level=WARN

Maven的assembly插件实现自定义打包

assembly.xml的配置项非常多,可以参考http://maven.apache.org/plugins/maven-assembly-plugin/assembly.html
以上只是用了很少的一部分。
format设置包输出的格式,以上格式设置的为zip格式,目前还支持zip,tar,tar.gz,tar.bz2,jar,dir,war格式
fileSet定义代码目录中与输出目录的映射,在该节点下还有 <includes/>,<excludes/>两个非常有用的节点。
比如:(本项目用的第2个配置)

1、打包管理中心用的

这个是配置管理中心用到的
<?xml version="1.0" encoding="UTF-8"?>
<assembly xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2 http://maven.apache.org/xsd/assembly-1.1.2.xsd">
    <!--该字符会添加到最终tar.gz包的名称后面做后缀-->
    <id>assembly</id>
    <!--指定打包个事为tar.gz.该类型压缩包在Linux中常见-->
    <formats>
        <format>tar.gz</format>
    </formats>
    <!--在tar.gz压缩包中是否包含根文件夹,改根文件夹名称和tar.gz去掉id后缀一致-->
    <includeBaseDirectory>true</includeBaseDirectory>
    <fileSets>
        <!--建项目根路径下assembly/bin路径中的内容打包到压缩包中的根目录下的bin目录中-->
        <fileSet>
            <!--相对项目根路径的相对路径-->
            <directory>assembly/bin</directory>
            <outputDirectory>bin</outputDirectory>
            <!--设置最终tar.gz中改文件夹下的权限,跟linux权限写法一直-->
            <fileMode>0755</fileMode>
        </fileSet>
        <!--将项目根路径下assembly/conf路径中的内容打包到压缩包中的根目录下的conf目录中-->
        <fileSet>
            <directory>assembly/conf</directory>
            <outputDirectory>conf</outputDirectory>
            <!--设置linux权限-->
            <fileMode>0644</fileMode>
        </fileSet>
    </fileSets>
    <!--将所有依赖的jar包打包到压缩包中的根目录下的lib目录中-->
    <!--此lib目录中包含自己开发的项目jar包以及demo_service.jar还有第三方的jar包-->
    <dependencySets>
        <dependencySet>
            <!--<useProjectArtifact>true</useProjectArtifact>-->
            <outputDirectory>lib</outputDirectory>            <!-- 将scope为runtime的依赖包打包到lib目录下。 -->
            <!--<scope>runtime</scope>-->
        </dependencySet>
    </dependencySets>
</assembly>

2、打包项目用java -jar xxx.jar发布服务要用到的 

这个是配置依赖包  本项目这个
<?xml version="1.0" encoding="UTF-8"?>
<assembly>
    <id></id>
    <formats>
        <format>tar.gz</format><!--打包的文件格式,也可以有:war zip-->
    </formats>
    <!--tar.gz压缩包下是否生成和项目名相同的根目录-->
    <includeBaseDirectory>true</includeBaseDirectory>
    <dependencySets>
        <dependencySet>
            <!--是否把本项目添加到依赖文件夹下-->
            <useProjectArtifact>true</useProjectArtifact>
            <outputDirectory>lib</outputDirectory>
            <!--将scope为runtime的依赖包打包-->
            <scope>runtime</scope>
        </dependencySet>
    </dependencySets>
    <fileSets>
        <fileSet>
            <directory>assembly/bin</directory>
            <outputDirectory>/</outputDirectory>
        </fileSet>
    </fileSets>
</assembly>

6、打包完成后,我们可以看到bin目录来存放启动脚本等文件,config为配置文件,lib下为运行时依赖的jar包。
使用maven assembly插件需要在pom文件中配置,添加这个插件(发布项目用2个、打包管理中心用第1、个)

1、打包管理中心

 <build>
        <plugins>        
           <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-assembly-plugin</artifactId>
                <configuration>
                	<descriptor>src/main/assembly/assembly.xml</descriptor><!--配置描述文件路径-->
                 </configuration>
                <executions>
                    <execution><!-- 配置执行器 -->
                        <id>make-assembly</id>
                        <phase>package</phase><!-- 绑定到package生命周期阶段上 -->
                        <goals>
                            <goal>single</goal><!-- 只运行一次 -->
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

2、部署项目

     <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.3.1</version>
                <configuration>
                    <archive>
                        <manifest>
                            <!--运行jar包时运行的主类,要求类全名-->
                            <mainClass>com.util.Provider</mainClass>
                            <!-- 是否指定项目classpath下的依赖 -->
                            <addClasspath>true</addClasspath>
                            <!-- 指定依赖的时候声明前缀 -->
                            <classpathPrefix>./</classpathPrefix>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-assembly-plugin</artifactId>
                <executions>
                    <execution><!-- 配置执行器 -->
                        <id>make-assembly</id>
                        <phase>package</phase><!-- 绑定到package生命周期阶段上 -->
                        <goals>
                            <goal>single</goal><!-- 只运行一次 -->
                        </goals>
                        <configuration>
                            <finalName>${project.name}</finalName>
                            <descriptor>assembly/assembly.xml</descriptor><!--配置描述文件路径-->
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

7、编译打包

8、打包完毕   解压到你想要解压的地方  (这个是管理中心配图)

项目部署配图  看ego_service_impl.tar.gz

java -jar xxx.jar &    //linux下启动jar   &表示后台运行
更多节点的用法可以去官网查询
http://maven.apache.org/plugins/maven-assembly-plugin/assembly.html

下面的文章会介绍打包后的包如何做成windows服务,linux服务。

参考资料

http://maven.apache.org/plugins/maven-assembly-plugin/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在使用Maven构建项目时,有时候会遇到idea中pom文件maven-assembly-plugin爆红的情况。这个问题通常是由于Maven仓库缺失相关的依赖或者版本不兼容导致的。针对这个问题,我们可以进行如下的解决步骤: 1. 检查Maven仓库中是否缺失相关的依赖:可以在Maven仓库中搜索相应的依赖,查看当前版本是否已被发布,并确认依赖是否存在于本地仓库中。如果缺失,则需要手动添加相应的依赖。在pom.xml文件中添加相应的依赖即可解决问题。 2. 检查maven-assembly-plugin版本是否与其他插件或Maven版本不兼容:可以尝试升级或降级maven-assembly-plugin的版本,或者升级Maven本身的版本。这样可能可以解决版本不兼容的问题。 3. 确认pom.xml文件中的配置是否正确:在pom.xml文件中,maven-assembly-plugin的配置可能存在问题,例如配置错误的目录结构、文件过滤规则等。需要检查配置是否正确。 总的来说,解决idea中pom文件maven-assembly-plugin爆红的问题,需要深入分析问题出现的原因,并进行适当的调整,才能实现问题的解决。但是需要注意的是,在做更改的时候一定要慎重,否则可能导致出现其他问题。 ### 回答2: 在使用 idea 进行 Maven 项目开发时,有可能会遇到 pom.xml 文件中的 maven-assembly-plugin 出现“爆红”的情况。这种情况一般是因为 pom.xml 中的 maven-assembly-plugin 配置出现了问题所造成的。 maven-assembly-plugin 是用来将多个 jar 文件打包成一个 jar 包或者将多个文件夹打包成一个 jar 包的 Maven 插件。如果我们想将一个项目(包含多个模块)打包成一个 jar 包或者包含多个依赖的 jar 包,就需要使用 maven-assembly-plugin 进行配置。 当 maven-assembly-plugin 出现“爆红”时,需要先检查 pom.xml 文件中该插件的配置是否正确,是否存在语法错误。通常情况下,出现“爆红”的原因可能是以下几种: 1. 缺少必要的依赖:maven-assembly-plugin 插件需要依赖其他的插件或库文件,缺少这些依赖会导致插件执行失败。此时,需要在 pom.xml 文件中添加缺失的依赖。 2. 版本不兼容:maven-assembly-plugin 插件需要与当前 Maven 的版本兼容,如果存在版本冲突,则可能会导致该插件无法正常工作。此时,可以检查 Maven 和插件的版本是否一致,如果不一致,则需要调整 Maven 或插件的版本。 3. 插件配置错误:在 pom.xml 文件中,配置 maven-assembly-plugin 时需要指定一些参数,如果这些参数设置错误,可能会导致插件无法正常工作。此时,可以根据具体情况查看插件配置文件,或者根据插件的文档进行设置。 总之,遇到 maven-assembly-plugin 爆红的问题时,需要首先检查 pom.xml 文件中的插件配置是否正确、依赖是否齐全、版本是否兼容等等。通过仔细排查问题,解决“爆红”问题是非常容易的。 ### 回答3: 在Maven项目中,POM文件是非常重要的配置文件,用于描述和管理项目中的依赖关系和构建信息。当我们在使用IDEA进行Maven项目开发时,有时会遇到POM文件中的maven-assembly-plugin爆红的情况。 首先,需要明确的是,maven-assembly-pluginMaven的一个插件,用于将项目打包成可执行的jar包或war包,并且可以将所依赖的所有jar包一并打包到打包文件中。该插件常用于将项目打包成可分发的安装包或者压缩包等。 那么当我们在IDEA中出现maven-assembly-plugin爆红的情况时,主要是由于以下原因: 1. Maven配置异常。在POM文件中,可能因为XML语法错误或者依赖配置不正确等原因导致插件无法正确加载或使用,从而导致插件爆红。 2. Maven本地配置问题。在Maven本地仓库中,可能缺失了maven-assembly-plugin依赖的相关jar包或版本不正确,导致插件无法正常使用,进而出现爆红情况。 3. IDEA插件异常。在IDEA中,可能由于插件版本过旧或与Maven版本不兼容等原因导致插件无法正确加载或者使用,从而导致爆红情况。 针对以上问题,我们可以采取如下解决措施: 1. 检查Maven配置问题。我们可以仔细检查POM文件中maven-assembly-plugin的依赖配置是否正确,或者在Maven的settings.xml文件中添加相应的依赖配置。 2. 检查Maven本地配置问题。我们可以尝试使用Maven命令来从远程仓库中获取maven-assembly-plugin依赖的相关jar包,并且将其手动放入Maven本地仓库中。 3. 检查IDEA插件问题。我们可以尝试更新IDEA中的Maven插件版本或者升级IDEA版本,以确保插件与Maven版本兼容性良好。 总之,在处理maven-assembly-plugin爆红问题时,我们需要注意仔细排查并解决相关问题,以确保Maven项目能够正常构建和运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值