IntelliJ IDEA远程调试Elasticsearch6.1.2

Stella981
• 阅读 423

在深入学习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上做以下设置:

  1. 打开elasticsearch-6.1.2/config/jvm.options文件,在尾部增加以下一行内容,注意5678是个没有被占用的端口:

    -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5678

  2. 正常启动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的电脑上,执行以下操作:

  1. 下载elasticsearch6.1.2源码,地址是:https://github.com/elastic/elasticsearch/releases

  2. 上述网站中有各个版本的release,找到我们需要 的6.1.2版本,然后下载压缩包,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

  3. 下载完毕后,解压得到elasticsearch-6.1.2目录,打开命令行进入该目录,执行gradle idea,将源码生成IntelliJ IDEA工程:

    gradle idea

  4. 打开IntelliJ IDEA,用import的方式导入上述工程,注意选择类型为Gradle,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

  5. 注意Gradle的版本号,推荐4.6版本,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

  6. 等待IDEA导入依赖和构建完成,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

  7. 源码导入成功后开始远程调试,菜单操作如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

  8. 新增一个远程配置,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

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

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

  11. 如果网络连接正常,会提示远程连接成功,如下图:
    IntelliJ IDEA远程调试Elasticsearch6.1.2

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

  13. 向elasticsearch发起一次PUT请求,创建名为"index101"的索引,url是"http://192.168.50.75:9200/index101",此时断点会立即生效,如下图,线程调用栈一目了然,是基于netty的server服务,变量值也应有尽有,对我们阅读源码很有帮助:
    IntelliJ IDEA远程调试Elasticsearch6.1.2
    至此,IntelliJ IDEA远程调试elasticsearch的实战就完成了,在您学习elasticsearch的过程中,希望本文能给您带来一些参考。

建议

除了远程调试,自己修改和编译elasticsearch源码也是有效的学习手段,推荐您参考文章《Elasticsearch6.1.2源码下载和编译构建》

欢迎关注我的公众号:程序员欣宸

IntelliJ IDEA远程调试Elasticsearch6.1.2

本文分享 CSDN - 程序员欣宸。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
暗箭伤人 暗箭伤人
6个月前
【www.ithunter.club】 20230922下午
不容易的2023年,我们一起努力【www.ithunter.club】(2023092208:00:00.8872062023092216:00:00.887206)1.人事招聘专员数名(可选远程或入职)2.招聘向坐标东京Yahoo、Shift、L
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这