分享

Hadoop学习之配置Eclipse远程调试Hadoop

本帖最后由 pig2 于 2015-4-27 00:35 编辑
问题导读:
1、什么是JPDA?
2、如何配置Eclipse调试Hadoop?




构建完成Hadoop项目后,接下来就应该跟踪Hadoop的运行情况,比如在命令行执行hadoop namenode–format时执行了Hadoop的那些代码。当然也可以直接通过阅读源代码的方式来做到这一点,但跟踪代码的执行情况更加直观,更容易理解。       动手配置Eclipse调试Hadoop之前,先大概学习一下JPDA(Java Platform Debugger Architecture,Java平台调试结构)。JPDA是一个多层的调试架构,使工具开发者可以容易地创建跨平台的,跨VM实现和JDK版本的调试器。JPDA包含三层:
  • JVM TI:Java VM ToolInterface,定义了VM提供的调试服务。
  • JDWP:Java DebugWire Protocol,定义了调试器进程和debuggee之间的通讯。Debuggee是正在被调试的进程,包含正在被调试的应用程序,运行该应用        程序的VM和后端的调试器。
  • JDI:Java DebugInterface,定义了高层次的Java接口,该接口允许工具开发者容易地编写远程调试器应用程序。
       JPDA的结构图如下所示:
       在简单介绍了JPDA的基本信息后(非常粗浅,更深入的学习可以参考Java的官方文档,地址

http://docs.oracle.com/javase/8/docs/technotes/guides/jpda/architecture.html#debuggee),下面就要看看该如何使用JPDA进行程序的调试。
      
VM的实现需要命令行选项加载JDWP代理用于调试。从5.0开始,-agentlib:jdwp选项用于加载JDWP代理和指定JDWP代理的选项,5.0之前的版本使用-Xdebug和-Xrunjdwp选项(5.0版本也支持-Xdebug和-Xrunjdwp选项)。如果目标虚拟机是5.0或者更新的版本,-agentlib:jdwp的使用方式为:-agentlib:jdwp=<sub-options>,5.0版本之前的使用方式为:-Xdebug(启用调试) -Xrunjdwp:<sub-options>。<sub-options>可以进一步指定,格式为:-agentlib:jdwp=<name1>[=<value1>],<name2>[=<value2>]...和 -Xrunjdwp:<name1>[=<value1>],<name2>[=<value2>]...。其中的name可以为如下:help、transport、server、address、timeout、launch、onthrow、onuncaught、suspend。其中常用的几个为transport、server、address和suspend,transport是指调试器和被调试的VM之间的通信方法,其值可以为dt_socket和dt_shmem;server的值为y或者n,默认值为n,当值为y时,监听调试器程序的连接,否则在address指定的地址上连接调试器;address指定了连接的地址,如果server=y,则在该地址上监听连接,若server=n,则在该地址上连接调试器;suspend的值为y或者n,如果值为y则表示JVM在调试器连接到它之前都会处于暂停状态(更详细的内容可以参考官网文档http://docs.oracle.com/javase/7/docs/technotes/guides/jpda/conninv.html)。下面看几个例子:

  1.     -Xdebug -Xrunjdwp:transport= dt_socket,address=1044,server=y,suspend=n  
  2.     -agentlib:jdwp=transport=dt_socket,server=y,address=8000  
  3.     -agentlib:jdwp=transport=dt_socket,address=myhost:8000  
复制代码
      
在学习了JPDA后,接下来就要配置Eclipse调试Hadoop。打开HADOOP_HOME/bin下的hadoop脚本,找到如下的代码:

  1.     elif [ "$COMMAND" = "namenode" ] ; then  
  2.       CLASS='org.apache.hadoop.hdfs.server.namenode.NameNode'  
  3.       HADOOP_OPTS="$HADOOP_OPTS $HADOOP_NAMENODE_OPTS "  
复制代码
      
将其改为:

  1.     elif [ "$COMMAND" = "namenode" ] ; then  
  2.       CLASS='org.apache.hadoop.hdfs.server.namenode.NameNode'  
  3.       HADOOP_OPTS="$HADOOP_OPTS $HADOOP_NAMENODE_OPTS -agentlib:jdwp=transport=dt_socket,server=y,address=6601,suspend=y"  
复制代码
      
新添加代码的意思为启用Java 调试器,并在端口6601上监听。做完上述的修改后再打开Eclipse,点击Run菜单下的Debug Configurations子菜单,如下图所示:

untitled.png

       先选择Remote Java Application,然后点击上面的New launch configuration按钮,出现下图所示的对话框,在右侧分别输入相应的信息,比如主机名称和端口号,端口与上面修改hadoop文件时address指定的值保持一致。


untitled.png

       做完上述的配置后,在命令上执行hadoop命令,比如hadoopnamenode –format,命令行的输出显示正在端口6601上监听:
  1.     [hadoop@hadoop conf]$ hadoop namenode -format
  2.     Listening for transport dt_socket at address: 6601
  3.     [hadoop@hadoop bin]$ start-all.sh
  4.     starting namenode, logging to /home/hadoop/hadoop-1.2.1/libexec/../logs/hadoop-hadoop-namenode-hadoop.out
  5.     Listening for transport dt_socket at address: 6601
复制代码
      点击上图右下侧的Debug按钮,开始调试Hadoop,调试的情况如下图所示,可以设置断点跟踪代码的执行情况。

untitled.png


       上面所讲的只是如何调试NameNode,DataNode的调试与此类似,不再赘述,而MapReduce作业的调试还有待进一步的研究。

资料来源:http://blog.csdn.net/skywalker_only/article/details/25539115

欢迎加入about云群371358502、39327136,云计算爱好者群,亦可关注about云腾讯认证空间||关注本站微信

已有(1)人评论

跳转到指定楼层
QQo0oBIQ 发表于 2015-4-27 09:15:56
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条