处理JAR依赖冲突编辑
如果你想使用Elasticsearch在您的Java应用程序中,您可能必须解决版本冲突与第三方如番石榴和Joda的依赖性。比如,也许Elasticsearch使用Joda 2.8,而代码使用Joda 2.1。
你有两个选择:
- 最简单的解决办法是升级。新模块的版本可能会有固定的老错误。你背后的进一步下降,难度将会升级。当然,有可能是您正在使用第三方依赖这反过来又取决于一个过时的版本的一个包,它阻止你升级。
- 第二个选择是搬迁的依赖和阴影他们与您自己的应用程序或Elasticsearch和任何所需的插件Elasticsearch客户机。
嵌入jar和依赖关系编辑
如果你想创建一个单独的jar包含您的应用程序和所有依赖项,不应该使用
maven-assembly-plugin
因为它不能处理META-INF/services
结构由Lucene需要罐子。相反,您可以使用
maven-shade-plugin
和配置是:<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>2.4.1</version> <executions> <execution> <phase>package</phase> <goals><goal>shade</goal></goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer"/> </transformers> </configuration> </execution> </executions> </plugin>
注意,如果你有一个main() 类
你想运行时自动调用java -jar yourjar.jar
,就将它添加到transformers
:<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>org.elasticsearch.demo.Generate</mainClass> </transformer>