前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >elasticsearch5.5.3 源码学习 idea下源码编译

elasticsearch5.5.3 源码学习 idea下源码编译

作者头像
杉枫
发布2018-04-02 14:41:41
1.1K0
发布2018-04-02 14:41:41
举报

  1、学习elasticsearch 源码,通过搜索“elasticsearch源码”,进行相关搜索。

     2、因源码gradle编译,选择gradle-3.5可以编译通过,对应elasticsearch 5.5.0,其他高版本gradle可能编译不过,

编译源码时需注意这一点。

        3、elasticsearch版本选择tag 版,tag为发布版,配置与代码一致。

        4、依赖jdk版本为1.8,idea设置ProjectSetting Project jdk版本,以及gradle jdk版本,以及complie jdk版本 

        5、idea -Des.path.home=D:\source\elasticsearch-5.5.3 -Dlog4j2.disable.jmx=true -Dtests.security.manager=false

            idea相关配置解决编译时各种报错。

            以及主class配置、以及classpath of module配置。

        5、jdk 1.8版本前几个版本jdk编译lambda存在bug,需要高版本jdk。

        6、idea module配置是core_main。

        7、module下jar采用对应发布版下module,里面为编译好的jar包。

        8、编译时plugins文件夹要有内容运行时可以没有内容。

        9、elasticsearch release版本下载链接 https://www.elastic.co/downloads/past-releases

     可能遇到的异常

  • ERROR: the system property [es.path.conf] must be set 原因是没有指定es.path.conf,设置-Des.path.conf=你调试源码版本对应的conf目录
  • Exception in thread "main" java.lang.IllegalStateException: path.home is not configured 原因是因为没有为elasticsearch配置path.home参数,可以在Edit Configuation中设置虚拟机参数:-Des.path.home=你下载的对应的elasticsearch的安装目录,这么做的原因 是elasticsearch在启动中会加载一些默认配置以及插件,我们直接加载elasticsearch安装目录下的配置和插件即可,后面会在源码中体现
  • 2017-06-23 14:00:44,760 main ERROR Could not register mbeans java.security.AccessControlException: access denied ("javax.management.MBeanTrustPermission" "register") 原因是因为elasticsearch在启动过程中使用到了jmx,我们这里禁止使用即可,配置也是在Edit Configuation中设置虚拟机参数 -Dlog4j2.disable.jmx=true
  • org.elasticsearch.bootstrap.StartupException: org.elasticsearch.bootstrap.BootstrapException: java.lang.IllegalStateException: jar hell!或Classname: org.elasticsearch.search.aggregations.matrix.MatrixAggregationPlugin due to jar hell 原因是因为elasticsearch中大量存在一个类或一个资源文件存在多个jar中,我们注释掉相应代码即可,主要是PluginsService中374行的JarHell.checkJarHell(union)以及 Bootstrap中220行的JarHell.checkJarHell(),最简单的方式就是将JarHell.checkJarHell()中的方法体注释掉
  • org.elasticsearch.bootstrap.StartupException: java.lang.IllegalArgumentException: plugin [aggs-matrix-stats] is incompatible with version [7.0.0-alpha1]; was designed for version [5.6.1] 原因是一般情况下我们调试的源码非某个发布版本,有些配置项并未发布,我们的配置与当前代码的版本匹配不上,这个时候我们需要将调试的源码设置成某个发布版本,一般来说,Elasticsearch每发布 一个稳定版本,都会有一个对应的tag,我们进入到ES源码目录下执行git tag, 我这里调试的版本为v5.6.1,所以执行git checkout v5.6.1,切换到v5.6.1tag.

       参考链接:

https://github.com/felayman/elasticsearch-full/blob/master/%E6%BA%90%E7%A0%81%E5%88%86%E6%9E%90/Elasticsearch%E6%BA%90%E7%A0%81%E5%88%86%E6%9E%90%E2%80%94%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87(%E4%B8%80).md

       https://bugs.openjdk.java.net/browse/JDK-8129589 

       待续。。。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  •      可能遇到的异常
相关产品与服务
Elasticsearch Service
腾讯云 Elasticsearch Service(ES)是云端全托管海量数据检索分析服务,拥有高性能自研内核,集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群,也支持免运维、自动弹性、按需使用的 Serverless 模式。使用 ES 您可以高效构建信息检索、日志分析、运维监控等服务,它独特的向量检索还可助您构建基于语义、图像的AI深度应用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档