Elasticsearch7.4源码编译记录

本文涉及的产品
Elasticsearch Serverless通用抵扣包,测试体验金 200元
简介: Elasticsearch7.4源码编译记录

Elasticsearch 7.4.3 源码编译记录

  • 建议:不要使用本机装的gradle,编译时会自动下载匹配版本的gradle
  • 获取源码编译结论,报错解决直接跳转文末

环境

  • Macos 10.4
  • idea 2019
  • jdk12
  • elasticsearch7.4 代码

编译过程

cd elasticsearch
./gradlew idea
  • 3、导入idea,选择导入

    选中 build.gradle ,idea会提示是否导入gradle项目,选择是

  • 4、打包对应版本的发行版文件,为一会启动做准备.这一步参考elasticsearch/TESTING.assciidoc文件
cd elasticsearch
./gradlew assemble
  • 5、打包成功之后,到elasticsearch/distribution/packages下找到自己对应系统的发行版文件

  • 6、解压elasticsearch-oss-7.4.3-SNAPSHOT-x86_64.rpm,然后在elasticsearch 同级别目录下新建文件夹home,并把解压后的文件放到home文件夹下


  • 7、找到elasticsearch/server/build.gradle,修改 compileOnly 改为compile,详细信息查看下面
// compileOnly project(':libs:elasticsearch-plugin-classloader'),compileOnly 改为compile
  • 8、idea设置项目JDK与gradle版本

    gradle版本与项目jdk保持一致

  • 9、指定刚才新建的home文件夹地址中的配置文件与数据存放地址,参数内容如下
-Des.path.conf=/cxt/codework/github/elasticsearch/7.4/home/config
-Des.path.home=/cxt/codework/github/elasticsearch/7.4/home
-Djava.security.policy=/cxt/codework/github/elasticsearch7.4/home/config/java.policy
-Dlog4j2.disable.jmx=true
  • Java.policy 文件内容如下
grant {
    permission java.lang.RuntimePermission "createClassLoader";
};

  • 10、到这,如果还不能启动,那就尽情的谷歌与百度吧,也欢迎留言一起讨论

遇到的报错

报错一

ERROR: the system property [es.path.conf] must be set

解决方案参考第九步

报错二

Caused by: java.lang.ClassNotFoundException: org.elasticsearch.plugins.ExtendedPluginsClassLoader

解决参考第七步

总结

编译失败的原因很大一部分是

1、gradle版本问题,jdk版本问题,所以多看代码中自带的CONTRIBUTING.md,README.textile,TESTING.asciidoc,确认当前版本所依赖的环境版本要求,起码能少踩很多的坑

2、本身如果安装了gradle,确保安装的gradle不要对项目生效,尽量使用代码中elasticsearch/gradle中文件夹指定的gradle,如果要使用本机安装的gradle,请确保gradle版本对项目版本兼容

3、把上面第七步,第九步的参数都配置基本问题不大了,实在打包不成功,也可以去官网下载发行版


相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
目录
相关文章
|
JSON 监控 Java
Elasticsearch 8.X reindex 源码剖析及提速指南
Elasticsearch 8.X reindex 源码剖析及提速指南
|
自然语言处理 Java 关系型数据库
ElasticSearch 实现分词全文检索 - SpringBoot 完整实现 Demo 附源码【完结篇】
ElasticSearch 实现分词全文检索 - SpringBoot 完整实现 Demo 附源码【完结篇】
293 0
|
Kubernetes Java 索引
Elasticsearch 源码探究 001——故障探测和恢复机制
Elasticsearch 源码探究 001——故障探测和恢复机制
|
Java iOS开发 MacOS
Elasticsearch 6.5源码编译最新版
Elasticsearch 6.5源码编译最新版
108 0
Elasticsearch 6.5源码编译最新版
|
Java API
SpringBoot【集成ElasticSearch 01】2种方式的高级客户端 RestHighLevelClient 使用(依赖+配置+客户端API测试源码)
SpringBoot【集成ElasticSearch 01】2种方式的高级客户端 RestHighLevelClient 使用(依赖+配置+客户端API测试源码)
528 1
|
前端开发 Java iOS开发
elasticsearch8.1源码编译笔记
elasticsearch8.1源码编译笔记
239 0
|
固态存储 架构师 开发工具
|
NoSQL Java API
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
227 0
|
Ubuntu Java 程序员
Elasticsearch6.1.2源码下载和编译构建
为了深入学习elasticsearch,研究其源码是种有效途径,本文简述了从下载到编译构建再运行起来的全部过程
291 0
Elasticsearch6.1.2源码下载和编译构建
|
Java 应用服务中间件
Elasticsearch-Jest 配置ES集群&源码解读
Elasticsearch-Jest 配置ES集群&源码解读
251 0