搭建Elasticsearch源码调试环境

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: 搭建Elasticsearch源码调试环境

真正掌握一门技术必须从源码抓起,源码调试环境必不可少,本文介绍如何在本地搭建Elasticsearch源码调试环境。

环境准备:

  • Elasticsearch7.13.2
  • Idea2021版本
  • gradle
  • git
  • Java

一、下载Elasticsearch源码

直接从elasticsearch仓库克隆代码到本地:

git clone https://github.com/elastic/elasticsearch.git

更加建议的是从自己的代码仓库中克隆:

1、在github上创建自己的账号,然后从elasticsearch fork到自己的仓库中

2、使用git将代码clone到自己的本地,使用git checkout将版本切换到7.13版本

二、安装多版本的JDK

由于编译Elasticsearch的需要,在Mac系统下需要安装多个JDK的版本,从JDK8~JDK15,以下说明安装和动态切换过程。

1、查看默认安装的JDK

lucas-os@zyingdeMacBook:~/workspace/elasticsearch$ java -version
java version "11" 2018-09-25
Java(TM) SE Runtime Environment 18.9 (build 11+28)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11+28, mixed mode)

2、使用以下命令查看安装路径:

lucas-os@zyingdeMacBook:~/workspace/elasticsearch$ /usr/libexec/java_home -v 11
/Library/Java/JavaVirtualMachines/jdk-11.jdk/Contents/Home

3、下载JDK8~JDK16对应版本dmg格式的安装包,按照默认配置进行安装,安装以后查看
/Library/Java/JavaVirtualMachines/
目录。

4、配置~/.bash_profile文件

#JDK8
export JAVA8_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home
#JDK9
export JAVA9_HOME=/Library/Java/JavaVirtualMachines/jdk-9.0.4.jdk/Contents/Home
#JDK10
export JAVA10_HOME=/Library/Java/JavaVirtualMachines/jdk-10.0.2.jdk/Contents/Home
#JDK11
export JAVA11_HOME=/Library/Java/JavaVirtualMachines/jdk-11.jdk/Contents/Home
#JDK12
export JAVA12_HOME=/Library/Java/JavaVirtualMachines/jdk-12.0.2.jdk/Contents/Home
#JDK13
export JAVA13_HOME=/Library/Java/JavaVirtualMachines/jdk-13.0.2.jdk/Contents/Home
#JDK14
export JAVA14_HOME=/Library/Java/JavaVirtualMachines/jdk-14.0.2.jdk/Contents/Home
#JDK15
export JAVA15_HOME=/Library/Java/JavaVirtualMachines/jdk-15.0.2.jdk/Contents/Home
#JDK16
export JAVA16_HOME=/Library/Java/JavaVirtualMachines/jdk-16.0.1.jdk/Contents/Home
#Default JDK
export JAVA_HOME=$JAVA15_HOME
#alias命令动态切换JDK版本
alias jdk8="export JAVA_HOME=$JAVA8_HOME"
alias jdk9="export JAVA_HOME=$JAVA9_HOME"
alias jdk10="export JAVA_HOME=$JAVA10_HOME"
alias jdk11="export JAVA_HOME=$JAVA11_HOME"
alias jdk12="export JAVA_HOME=$JAVA12_HOME"
alias jdk13="export JAVA_HOME=$JAVA13_HOME"
alias jdk14="export JAVA_HOME=$JAVA14_HOME"
alias jdk15="export JAVA_HOME=$JAVA15_HOME"
alias jdk16="export JAVA_HOME=$JAVA16_HOME"

5、动态切换

使用alias命令配置jdk别名,可以使用jdk8~jdk16动态切换默认的jdk。

三、导入Idea

1、打开IDEA,File->New_->Project from Existing Sources,选择导入为gradle工程(elasticsearch是使用gradle作为管理和编译工具的。)

2、构建工程

./gradlew run

这时候会使用工程默认指定的gradle下载依赖项,然后进行工程构建启动本地elasticsearch实例。

lucas-os@zyingdeMacBook:~/workspace/elasticsearch$ ./gradlew run
=======================================
Elasticsearch Build Hamster says Hello!
  Gradle Version        : 7.0.1
  OS Info               : Mac OS X 10.13.6 (x86_64)
  JDK Version           : 16.0.1 (Oracle)
  JAVA_HOME             : /Library/Java/JavaVirtualMachines/jdk-16.0.1.jdk/Contents/Home
  Random Testing Seed   : FE7643423B53C5E9
  In FIPS 140 mode      : false
=======================================
> Task :run
.
.
.
.
.
.
<============-> 99% EXECUTING [32m 25s]
> :run
> IDLE
> IDLE
> IDLE

当看到以上输出的时候证明本地elasticsearch已经启动成功,这时候在浏览器上输入`localhost:9200`,会提示输入账号和密码,这是因为elasticsearch内置了一些用户和角色,用以提供认证功能,默认情况下这些用户是没有设置密码的,在设置密码前无法访问。

这些角色有elastic、apm_system、kibana_system、logstash_system、beats_system、remote_monitoring_user。

由于默认的xpack.security.enabled的值为true,所以开启了认证,为了方便可以将此先配置为false。

xpack.security.enabled: false

此时可以看到集群的相关信息:

{
  "name" : "runTask-0",
  "cluster_name" : "runTask",
  "cluster_uuid" : "wqWiRAWJS1a8ie9Tic9L3A",
  "version" : {
    "number" : "7.13.2-SNAPSHOT",
    "build_flavor" : "default",
    "build_type" : "zip",
    "build_hash" : "e8def7f7024f26aa14eeb68a69dafc3ee2c2ad47",
    "build_date" : "2021-06-12T03:55:12.931748900Z",
    "build_snapshot" : true,
    "lucene_version" : "8.8.2",
    "minimum_wire_compatibility_version" : "6.8.0",
    "minimum_index_compatibility_version" : "6.0.0-beta1"
  },
  "tagline" : "You Know, for Search"

此时就已经完成了整体环境的搭建,可以进行debug或者修改代码后本地调试了。

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
2月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
6月前
|
JSON 监控 Java
Elasticsearch 8.X reindex 源码剖析及提速指南
Elasticsearch 8.X reindex 源码剖析及提速指南
85 0
|
3月前
|
自然语言处理 Java 关系型数据库
ElasticSearch 实现分词全文检索 - SpringBoot 完整实现 Demo 附源码【完结篇】
ElasticSearch 实现分词全文检索 - SpringBoot 完整实现 Demo 附源码【完结篇】
47 0
|
6月前
|
Kubernetes Java 索引
Elasticsearch 源码探究 001——故障探测和恢复机制
Elasticsearch 源码探究 001——故障探测和恢复机制
79 0
|
6月前
|
Java iOS开发 MacOS
Elasticsearch 6.5源码编译最新版
Elasticsearch 6.5源码编译最新版
42 0
Elasticsearch 6.5源码编译最新版
|
6月前
|
前端开发 Java iOS开发
elasticsearch8.1源码编译笔记
elasticsearch8.1源码编译笔记
136 0
|
6月前
|
Java iOS开发 MacOS
Elasticsearch7.4源码编译记录
Elasticsearch7.4源码编译记录
52 0
|
6月前
|
NoSQL Java API
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
109 0
|
3天前
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
11 5
|
1月前
|
存储 JSON Java
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。
这篇文章是关于Elasticsearch的学习指南,包括了解Elasticsearch、版本对应、安装运行Elasticsearch和Kibana、安装head插件和elasticsearch-ik分词器的步骤。
102 0
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。