当前位置: 首页 > news >正文

使用maven-shade-plugin解决es跨版本冲突

问题:应用迁移合并,需要把两个应用合并起来,其中一个es使用的5.x,一个使用的6.x,导致项目启动报错,需要将两个大版本的es隔离开。

解决方案:使用maven自带的plugin来解决  maven-shade-plugin

maven-shade-plugin提供了两大基本功能:

  1. 将依赖的jar包打包到当前jar包(常规打包是不会将所依赖jar包打进来的);
  2. 对依赖的jar包进行重命名(用于类的隔离);

使用方法:

一、我们先做一个jar包,其中pom文件如下(伪代码,只展示shade部分)。

主要做几件事:

1.引入和原项目不同的es版本

2.引入maven-shade-plugin将es对应的路径重命名

3.将该包打成一个新的jar,maven工具里的package进行打包

<?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>com.test</groupId><artifactId>es</artifactId><version>1.3-es-test-SNAPSHOT</version><properties><es.version>6.3.2</es.version></properties><dependencies><!-- es --><dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>${es.version}</version></dependency><dependency><groupId>org.elasticsearch.client</groupId><artifactId>transport</artifactId><version>${es.version}</version></dependency><!-- es end--></dependencies><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-shade-plugin</artifactId><version>3.2.4</version><executions><execution><phase>package</phase><goals><goal>shade</goal></goals><configuration><createDependencyReducedPom>true</createDependencyReducedPom><relocations><relocation><!-- 改名前 --><pattern>org.elasticsearch</pattern><!-- 改名后 --><shadedPattern>shaded.rest6.org.elasticsearch</shadedPattern></relocation><relocation><!-- 改名前 --><pattern>org.apache.lucene</pattern><!-- 改名后 --><shadedPattern>shaded.rest6.org.apache.lucene</shadedPattern></relocation><relocation><!-- 改名前 --><pattern>org.joda.time</pattern><!-- 改名后 --><shadedPattern>shaded.rest6.org.joda.time</shadedPattern></relocation></relocations></configuration></execution></executions></plugin></plugins></build>
</project>

二、在原项目引入刚刚打的jar包,pom文件引用

 <dependency><groupId>com.test</groupId><artifactId>es</artifactId><version>1.3-es-test-SNAPSHOT</version></dependency>

三、将原项目中引入的es6相关版本的路径改名,能成功引入不报红就没什么问题

 通过上面方式可以解决各种依赖包冲突问题,使多个版本共存。

http://www.dtcms.com/a/315725.html

相关文章:

  • 微信小程序功能实现:页面导航与跳转
  • jenkins插件Active Choices的使用通过参数动态控制多选参数的选项
  • LHA6958D是一款代替AD7606的芯片
  • 【前端】网站favicon图标制作
  • MyBatisPlus查询数据库中所有表的数据(AI)
  • 使标签垂直水平居中的多种方法
  • 自动驾驶控制算法——MPC控制算法
  • 数据结构 实现单链表
  • Vue3核心语法进阶(Props)
  • C语言:选择排序算法深度剖析!
  • nodejs 编码初体验
  • JAVA无人共享球杆柜系统球杆柜租赁系统源码支持微信小程序
  • 嵌入式硬件中运放的基本控制原理
  • 基于k8s环境下的pulsar常用命令(上)
  • 达梦分布式集群DPC_分布式任务执行拆分流程_yxy
  • 安全测绘之敏感网络资产排查指南
  • 在Linux上部署RabbitMQ、Redis、ElasticSearch
  • Taro Hooks 完整分类详解
  • 深度解析随机森林 API:参数奥秘与调优指南
  • 在AI时代,如何制定有效的职业规划?AI时代职业规划+AI产品经理角色
  • 【学习笔记】NTP时间同步验证
  • Kali Linux 2025.2基于MITRE ATTCK框架
  • DPU(数据处理单元)架构中,SoC(系统级芯片)与FPGA(现场可编程门阵列)之间的数据交互
  • 山东移动e企组网技术分析:底层架构与实现方式
  • 第12届蓝桥杯Scratch_选拔赛_初级组_真题2020年11月21日
  • SpringBoot3.x入门到精通系列:4.2 整合 Kafka 详解
  • Linux第十二讲:线程概念与控制
  • 前端保持和服务器时间同步的方法【使用vue3举例】
  • Qt 音频播放全攻略:常用函数、实战示例与资源获取
  • 升级 Elasticsearch 到新的 AWS Java SDK