查看原文
其他

教你如何在 IDEA 远程 Debug ElasticSearch

zhisheng zhisheng 2021-09-05


前提

之前在 源码阅读环境搭建文章 中写过我遇到的一个问题迟迟没有解决,也一直困扰着我。问题如下,在启动的时候解决掉其他异常和报错后,最后剩下这个错误一直解决不了:

1[2018-08-01T09:44:27,370][ERROR][o.e.b.ElasticsearchUncaughtExceptionHandler] [] fatal error in thread [main], exiting
2java.lang.NoClassDefFoundError: org/elasticsearch/plugins/ExtendedPluginsClassLoader
3    at org.elasticsearch.plugins.PluginsService.loadBundle(PluginsService.java:632) ~[main/:?]
4    at org.elasticsearch.plugins.PluginsService.loadBundles(PluginsService.java:557) ~[main/:?]
5    at org.elasticsearch.plugins.PluginsService.<init>(PluginsService.java:162) ~[main/:?]
6    at org.elasticsearch.node.Node.<init>(Node.java:311) ~[main/:?]
7    at org.elasticsearch.node.Node.<init>(Node.java:252) ~[main/:?]
8    at org.elasticsearch.bootstrap.Bootstrap$5.<init>(Bootstrap.java:213) ~[main/:?]
9    at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:213) ~[main/:?]
10    at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:326) ~[main/:?]
11    at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:136) ~[main/:?]
12    at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:127) ~[main/:?]
13    at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86) ~[main/:?]
14    at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124) ~[main/:?]
15    at org.elasticsearch.cli.Command.main(Command.java:90) ~[main/:?]
16    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:93) ~[main/:?]
17    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:86) ~[main/:?]
18Caused by: java.lang.ClassNotFoundException: org.elasticsearch.plugins.ExtendedPluginsClassLoader
19    at jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:582) ~[?:?]
20    at jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:190) ~[?:?]
21    at java.lang.ClassLoader.loadClass(ClassLoader.java:499) ~[?:?]
22    ... 15 more

网上的解决办法也试了很多遍,包括自己也在 GitHub issue 提问了,也没能解决。然后后面自己分享文章在掘金也发现有人和我有同样的问题。

下面讲讲另一种可以让你继续看源码的方法。

远程 Debug

前提条件是你之前已经把项目导入进 IDEA 了,如果你还没了解,请看之前的文章,这里不重复了。

启动一个实例

在你 git 拉取下的代码,切换你要阅读的分支代码后,执行下面这条命令启动一个 debug 的实例:

1./gradlew run --debug-jvm

启动等会后,就可以看到启动好后的端口号为 8000 了。

配置 IDEA

新建一个远程的 debug:

配置如下图:

接下来点击 OK 就好了。

然后点击下面的 debug 图标:

启动后如下:

这时就可以发现是可以把整个流程全启动了,也不会报什么错误!

流程全启动后,你会发现终端的日志都打印出来了(注意:这时不是打印在你的 IDEA 控制台)

总结

遇到问题,多思考,多搜索,多想办法解决!这样才能够不断的提升你解决问题的能力!

关注我

zhisheng

最后

转载请务必注明文章出处为:

http://www.54tianzhisheng.cn/2018/08/14/idea-remote-debug-elasticsearch/

相关文章

1、渣渣菜鸡为什么要看 ElasticSearch 源码?

2、渣渣菜鸡的 ElasticSearch 源码解析 —— 环境搭建

3、Elasticsearch 默认分词器

4、Elasticsearch 可用中分分词器

5、Elasticsearch 自定义分词器

6、全文搜索引擎 Elasticsearch 集群搭建入门教程

7、Elasticsearch 系列文章(三):ElasticSearch 集群监控

8、Elasticsearch 系列文章(四):ElasticSearch 单个节点监控

9、Elasticsearch 系列文章(五):ELK 实时日志分析平台环境搭建

: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存