开启flume的远程调试功能

各种组件,比如tomcat、storm、flume,我们都可以通过JMX方式开启远程调试,主要可以用来跟踪源码,了解程序内部的运行机制,其次,也有利于你修改源码。

首先,本质上是要修改flume本身启动的配置文件的jvm配置部分。

找到flume目录下的bin文件夹,下面会有个flume-ng文件,这便是flume本身启动脚本所在,找到如下部分:

1
2
3
4
5
# set default params
FLUME_CLASSPATH=""
FLUME_JAVA_LIBRARY_PATH=""
JAVA_OPTS="-Xmx20m"
LD_LIBRARY_PATH=""

可以看到这是配置jvm部分,替换为JMX远程调试配置,这种配置网上很多,我的如下:

1
2
3
4
5
# set default params
FLUME_CLASSPATH=""
FLUME_JAVA_LIBRARY_PATH=""
JAVA_OPTS="-Xmx20m -Xdebug -Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=y"
LD_LIBRARY_PATH=""

这里设定了远程调试的port:8787。

好了,到了这里,你可以在eclipse里面开启远程调试模式,具体如下:

new一个,然后进行配置,主要是主机IP和上面那个port,如下:

然后,eclipse导入flume源码,尽情享受调试源码的乐趣吧,你也可以随意修改。

 

PS:源码调试是一个学习源码的快速途径,很多组件,诸如storm,tomcat,hadoop等等都可以这样进行JMX配置,大同小异。

posted @   为了生活,加油  阅读(2989)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示