IntelliJ IDEA远程调试Elasticsearch6.1.2

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: 本文实战了通过IntelliJ IDEA远程调试Elasticsearch,作为我们学习es源码时有效的辅助手段

欢迎访问我的GitHub

这里分类和汇总了欣宸的全部原创(含配套源码): https://github.com/zq2599/blog_demos
  • 在深入学习elasticsearch的过程中,遇到有疑惑的源码时,如果能打断点单步调试,往往会取得事半功倍的效果,今天的实战内容就是通过IntelliJ IDEA远程连接运行中的elasticsearch服务,然后单步运行代码;

环境信息

  • 本次实战会用到两台电脑,一台Ubuntu运行着elasticsearch6.1.2版本,另一台Win10运行着IntelliJ IDEA,详细的版本信息如下:
  1. 操作系统:Ubuntu 18.04.2 LTS
  2. JDK:1.8.0_191
  3. Gradle:4.6
  4. elasticsearch:6.1.2
  5. IntelliJ IDEA: 2018.2.4 (Ultimate Edition)
  • 当然,您也可以将elasticsearch和IntelliJ IEDA运行在同一台电脑上,并没有什么差别;

Ubuntu上的操作

  • 在Ubuntu上做以下设置:
  • 打开elasticsearch-6.1.2/config/jvm.options文件,在尾部增加以下一行内容,注意5678是个没有被占用的端口:
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5678
  • 正常启动elasticsearch,如果没有选择后台启动,可以在控制台看到如下信息,可见已经开始监听5678端口了:
Listening for transport dt_socket at address: 5678
[2019-04-20T07:10:36,449][INFO ][o.e.n.Node               ] [] initializing ...
[2019-04-20T07:10:36,570][INFO ][o.e.e.NodeEnvironment    ] [stNJgHX] using [1] data paths, mounts [[/ (/dev/sda2)]], net usable_space [93.5gb], net total_space [109gb], types [ext4]
[2019-04-20T07:10:36,570][INFO ][o.e.e.NodeEnvironment    ] [stNJgHX] heap size [990.7mb], compressed ordinary object pointers [true]
[2019-04-20T07:10:36,572][INFO ][o.e.n.Node               ] node name [stNJgHX] derived from node ID [stNJgHXSQZObhO-ze917hA]; set [node.name] to override

IntelliJ IDEA上的操作

  • elasticsearch启动成功后,回到要运行IntelliJ IDEA的电脑上,执行以下操作:
  • 下载elasticsearch6.1.2源码,地址是:https://github.com/elastic/elasticsearch/releases
  • 上述网站中有各个版本的release,找到我们需要 的6.1.2版本,然后下载压缩包,如下图:

在这里插入图片描述

  • 下载完毕后,解压得到elasticsearch-6.1.2目录,打开命令行进入该目录,执行gradle idea,将源码生成IntelliJ IDEA工程:
gradle idea
  • 打开IntelliJ IDEA,用import的方式导入上述工程,注意选择类型为Gradle,如下图:

在这里插入图片描述

  • 注意Gradle的版本号,推荐4.6版本,如下图:

在这里插入图片描述

  • 等待IDEA导入依赖和构建完成,如下图:

在这里插入图片描述

  • 源码导入成功后开始远程调试,菜单操作如下图:

在这里插入图片描述

  • 新增一个远程配置,如下图:

在这里插入图片描述

  • 在新配置项的设置窗口,按照下图所示进行配置,输入合适的配置名称,elasticsearch服务所在机器的IP地址,端口号5678,然后点击底部的OK按钮:

在这里插入图片描述

  • 如下图,这时候在工具栏上可以看见上面配置的elastic6.1.2,选中后点击红框2中的debug按钮,即可开始远程连接:

在这里插入图片描述

  • 如果网络连接正常,会提示远程连接成功,如下图:

在这里插入图片描述

  • 来试试断点的效果吧,打开类org.elasticsearch.rest.RestController,这是elasticsearch处理web请求的入口类,在dispatchRequest方法中打个断点,位置是调用tryAllHandlers方法那一行,如下图红框所示:

在这里插入图片描述

  • 向elasticsearch发起一次PUT请求,创建名为"index101"的索引,url是"http://192.168.50.75:9200/index101",此时断点会立即生效,如下图,线程调用栈一目了然,是基于netty的server服务,变量值也应有尽有,对我们阅读源码很有帮助:

在这里插入图片描述

  • 至此,IntelliJ IDEA远程调试elasticsearch的实战就完成了,在您学习elasticsearch的过程中,希望本文能给您带来一些参考。

建议

欢迎关注阿里云开发者社区博客:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...
相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
6月前
|
Java 编译器 Maven
使用intellij idea搭建SSM架构的maven项目 详细
使用intellij idea搭建SSM架构的maven项目 详细
101 4
|
5月前
|
IDE Oracle Java
day4:JDK、IntelliJ IDEA的安装和环境变量配置
【7月更文挑战第4天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
234 0
|
7月前
|
Java 网络安全 网络协议
IDEA实现java远程调试
IDEA实现java远程调试
1152 3
|
5月前
|
网络协议 安全 Linux
在IntelliJ IDEA中使用固定公网地址远程SSH连接服务器环境进行开发
在IntelliJ IDEA中使用固定公网地址远程SSH连接服务器环境进行开发
119 2
|
6月前
|
Linux 开发工具 Windows
在WSL2中安装IntelliJ IDEA开发工具
在WSL2中安装IntelliJ IDEA开发工具
632 2
|
6月前
|
IDE Java Scala
IntelliJ IDEA 2023.3 最新变化2
IntelliJ IDEA 2023.3 最新变化
|
5月前
|
缓存 Java Maven
IntelliJ IDEA中无法加载jar包导致出现“cannot resolve symbol...”问题的解决
IntelliJ IDEA中无法加载jar包导致出现“cannot resolve symbol...”问题的解决
221 0
|
5月前
|
存储 Oracle Java
Java面试题:描述如何使用Eclipse或IntelliJ IDEA进行Java开发?
Java面试题:描述如何使用Eclipse或IntelliJ IDEA进行Java开发?
56 0
|
6月前
|
SQL 分布式计算 大数据
MaxCompute产品使用合集之如何在本地IDE(如IntelliJ IDEA)中配置MaxCompute (mc) 的任务和调试SQL
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
6月前
|
IDE Java 项目管理
Java入门——Intellij IDEA简介、使用IDEA开发程序、IDEA常用快捷键、IDEA其他操作
Java入门——Intellij IDEA简介、使用IDEA开发程序、IDEA常用快捷键、IDEA其他操作
109 3