让hadoop远程调试飞

 

读hadoop源代码时,经常需要调试源代码。hadoop几乎所有的进程的启动最终全部依靠$HADOOP_HOME/bin/hadoop 脚本实现,开始就简单的在需要的地方添加JDWP的debug选项,做的多了,感觉不够自动化,简单修改了一下hadoop这个脚本,让自动化远程调试飞!

修改的脚本如下:

 

在$HADOOP_HOME/bin/hadoop中后添加:

 

 

 

 

在$HADOOP_HOME/bin/hadoop中246行后添加( # cygwin path translation前):

 

 

 

这样,hadoop脚本会根据COMMAND和$HADOOP_HOME/bin/hadoop.debug 内容决定是否开启调试。

 

比如,想调试datanode,执行echo datanode > $HADOOP_HOME/bin/hadoop.debug

启动hadoop时,仅仅datanode会开启remote debug

console显示:

 

 

想开启namenode等调试,仅仅需要echo 你想调试的command > $HADOOP_HOME/bin/hadoop.debug 

hadoop命令支持的所有COMMAND都可以轻松开启调试:

附hadoop所有命令:

 

 

 

--EOF--

 

 

 

 

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值