本文主要是介绍Elasticsearch java API (3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
处理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>
这篇关于Elasticsearch java API (3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!