记一次Jar冲突解决

背景:

一个老的Boot项目引入微服务,所以打算使用feign

1.微服务的feign接口打包

2.引入POM

<dependency>
        <groupId>com.xxx</groupId>
        <artifactId>xxx-api</artifactId>
        <version>1.0.22</version>
        <classifier>interface</classifier>
</dependency>

3.启动分析:

1).启动空指针

2).项目启动后,访问无日志,无响应(除第一次会有几行日志)

 

原因:

jenkins在部署项目时,把feign接口包里面的pom也扫到了,所以把feign接口所在的项目引用的jar也打进去了

导致项目会多出很多jar,启动报错。

解决:

feign接口所在的项目引用jar每个都加上

<optional>true</optional>

或者:

<plugin>
   <groupId>org.apache.maven.plugins</groupId>
   <artifactId>maven-jar-plugin</artifactId>
   <executions>
      <execution>
         <id>interface</id>
         <goals>
            <goal>jar</goal>
         </goals>
         <phase>package</phase>
         <configuration>
            <classifier>interface</classifier>
            <includes>
               <include>**/com/xxx/**/feign/**</include>
            </includes>
            <finalName>${project.artifactId}-${project.version}</finalName>
            <archive>
               <addMavenDescriptor>false</addMavenDescriptor>
            </archive>
         </configuration>
      </execution>
   </executions>
</plugin>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果在使用 Flink 和 Phoenix 时出现了 jar冲突,可以尝试以下解决方法: 1. 排除冲突jar 包 在 Maven 或 Gradle 依赖中可以指定排除某些 jar 包的依赖,例如: ``` <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-connector-kafka_2.11</artifactId> <version>${flink.version}</version> <exclusions> <exclusion> <groupId>org.apache.kafka</groupId> <artifactId>kafka-clients</artifactId> </exclusion> </exclusions> </dependency> ``` 这里排除了 `flink-connector-kafka_2.11` 的依赖中的 `kafka-clients` jar 包。 2. 引入 shade 插件 可以使用 Maven 的 shade 插件将依赖的 jar 包重命名并打包到一个新的 jar 包中,避免 jar冲突,例如: ```xml <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.2.3</version> <configuration> <relocations> <relocation> <pattern>com.google.common</pattern> <shadedPattern>shade.com.google.common</shadedPattern> </relocation> </relocations> </configuration> </plugin> ``` 这里将依赖的 `com.google.common` 包重命名为 `shade.com.google.common`。 3. 修改 Flink 的 classpath 可以将依赖的 jar 包放到 Flink 的 classpath 中,例如在启动 Flink JobManager 或 TaskManager 时指定 classpath: ``` ./bin/flink run -m yarn-cluster -yn 3 -c com.acme.MyFlinkJob -classpath "/path/to/dependency/*" /path/to/MyFlinkJob.jar ``` 这里将依赖的 jar 包放到了 `/path/to/dependency/` 目录下,并通过 `-classpath` 参数将该目录下所有 jar 包加入到 Flink 的 classpath 中。 希望这些方法可以帮助你解决 jar冲突问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张小帅和刘美美

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值