Hadoop配置和使用问题记录

关于hadoop如何配置的教程网上已经有不少了,配合hadoop主页上的说明,基本可以顺利在多台机器上配置好hadoop集群。这里记录的是我在实际配置和使用hadoop时遇到的问题,其中一些属于hadoop周边,如ssh配置时容易遇到的问题和解决方法,供大家参考。我目前是在windows xp里通过cygwin安装的hadoop,版本是0.17.2.1。

1. 安装cygwin。在www.cygwin.com下载网络安装包,在选择组件的时候建议直接把openssh组件选中,有些版本的cygwin似乎不会自动安装diffutils组件,所以需要手工选中一下,否则配置ssh时会提示缺少该组件包。

2. cygwin控制台里的缺省提示符不太习惯,用export PS1="\u@\w$"设一下好多了。

3. 配置sshd比较简单,可以参考这个链接。在ssh-host-config时问到“Should privilege separation be used? (yes/no)”时回答no即可,如果由于安全因素要回答yes时,在启动sshd时有可能遇到“Privilege separation user sshd does not exist”的错误信息,解决方法可参考这个链接

4. 在配置ssh使用证书方式自动验证时花了一些时间,后来觉得可能是由于机器上有两个版本的cygwin的缘故,因为在另一台机器上安装就没有出现问题。在使用ssh-keygen -t rsa命令后提示输入密码时,直接按两次回车即可。公钥的复制等过程这里不再赘述。

5. 试图在Eclipse里运行hadoop的WordCount程序时提示异常:“javax.security.auth.login.LoginException: Login failed: CreateProcess: whoami error=2”,解决方法是把c:\cygwin\bin加入系统的path环境变量,然后重启Eclipse以便改动生效。

6. 在Eclipse里运行WordCount时遇到java heap size不够的异常,在运行配置里加入-Xms200M就可以解决。(hadoop的helloworld要求的内存比较多?)

7. 当要运行的运算依赖第三方类库时,这个链接有所讨论,但暂时没看到除了在命令行里使用hadoop jar命令以外的解决方法,比如在0.17.2和0.18.1版本里我都没有看到JobConf类里有类似addJar()这样的方法,在JobConf#setJar()里使用逗号分隔多个jar文件的方式则会报找不到文件的错误。解决方式可能有两个:a)把所需要的第三方jar文件复制到每个节点机器的jre里(暂时没有试验) b)把第三方jar包和自己的类打到一个包里。

update: 在网上找到另一种方式,通过DistributedCache实现,原文里可能有笔误,我试验正确的方法是调用DistributedCache.addArchiveToClassPath()方法,注意其第一个参数必须是相对路径,如“/test/lib /my.jar”,而不能是像“hdfs://192.168.0.5:47110/test/lib/my.jar”这样的绝对路径。关于 DistributedCache的说明在里有一些。

8. 调试mapreduce程序的方式,在这个链接里讲得比较清楚了,因为很有用所以特意重复一次。如果文件存放在HDFS里,那么只需要调用JobConf#.set("mapred.job.tracker", "local");即可;如果文件也是存在本地的,还需要调用JobConf#set("fs.default.name", "local");方法。我通常让文件存在HDFS里调试,因为要使用本地文件要么参数需要改变,要么代码需要改变,维护两个环境很麻烦。在程序里用System.out.println()输出的内容可以在datanode的hadoop安装路径的logs/userlogs目录里找到。

 

9. 当使用自定义InputFormat时,特别是使用EMF模型元素作为key的时候,需要注意并不是在代码的任何地方都能得到xmi:id的值的。具体来说,在WritableComparable#write()方法里能得到(前提是该对象本来就有resource,即eobj.eResource()!=null),而在WritableComparable#readFields()里是不能得到的,在RecordWriter#write()方法里同样不能得到,因为后两者的EMF元素对象都是反序列化得到的,已经不是内存里原来的那个实例了。

10. map进行到100%后,reduce过程进行到某个数值(如16%)后就不再继续,直到被hadoop强制关闭。在tasknode的log里记录如下:

 

2008 - 11 - 20   11 : 17 : 06 , 455  INFO org.apache.hadoop.mapred.TaskTracker: task_200811191041_0015_r_000000_0  0.16666667 %  reduce  >  copy ( 6  of  12  at  0.00  MB / s)  >  
2008 - 11 - 20   11 : 17 : 09 , 455  INFO org.apache.hadoop.mapred.TaskTracker: task_200811191041_0015_r_000000_0  0.16666667 %  reduce  >  copy ( 6  of  12  at  0.00  MB / s)  >  
2008 - 11 - 20   11 : 17 : 15 , 455  INFO org.apache.hadoop.mapred.TaskTracker: task_200811191041_0015_r_000000_0  0.16666667 %  reduce  >  copy ( 6  of  12  at  0.00  MB / s)  >  
2008 - 11 - 20   11 : 17 : 18 , 705  FATAL org.apache.hadoop.mapred.TaskTracker: Task: task_200811191041_0015_r_000000_0  -  Killed due to Shuffle Failure: Exceeded MAX_FAILED_UNIQUE_FETCHES; bailing - out.
2008 - 11 - 20   11 : 17 : 18 , 705  INFO org.apache.hadoop.mapred.TaskTracker: About to purge task: task_200811191041_0015_r_000000_0
2008 - 11 - 20   11 : 17 : 18 , 705  INFO org.apache.hadoop.mapred.TaskRunner: task_200811191041_0015_r_000000_0 done; removing files.
2008 - 11 - 20   11 : 17 : 18 , 705  WARN org.apache.hadoop.mapred.TaskTracker: Unknown child task finshed: task_200811191041_0015_r_000000_0. Ignored.
2008 - 11 - 20   11 : 17 : 40 , 845  INFO org.apache.hadoop.mapred.TaskTracker: Received  ' KillJobAction '   for  job: job_200811191041_0015
2008 - 11 - 20   11 : 17 : 40 , 845  INFO org.apache.hadoop.mapred.TaskRunner: task_200811191041_0015_m_000011_0 done; removing files.
2008 - 11 - 20   11 : 17 : 40 , 845  INFO org.apache.hadoop.mapred.TaskRunner: task_200811191041_0015_m_000005_0 done; removing files.

 

在我的java application的控制台里的输入如下:

08 / 11 / 20   11 : 06 : 39  INFO mapred.JobClient:  map  96 %  reduce  11 %
08 / 11 / 20   11 : 06 : 40  INFO mapred.JobClient:  map  100 %  reduce  11 %
08 / 11 / 20   11 : 06 : 43  INFO mapred.JobClient:  map  100 %  reduce  13 %
08 / 11 / 20   11 : 06 : 47  INFO mapred.JobClient:  map  100 %  reduce  16 %  (在这里停很久)
08 / 11 / 20   11 : 17 : 12  INFO mapred.JobClient:  map  100 %  reduce  0 %
08 / 11 / 20   11 : 17 : 12  INFO mapred.JobClient: Task Id : task_200811191041_0015_r_000000_0, Status : FAILED
Shuffle Error: Exceeded MAX_FAILED_UNIQUE_FETCHES; bailing
- out.
08 / 11 / 20   11 : 17 : 14  WARN mapred.JobClient: Error reading task outputnode2
08 / 11 / 20   11 : 17 : 14  WARN mapred.JobClient: Error reading task outputnode2
08 / 11 / 20   11 : 17 : 25  INFO mapred.JobClient:  map  100 %  reduce  16 %
08 / 11 / 20   11 : 17 : 30  INFO mapred.JobClient:  map  100 %  reduce  25 %
08 / 11 / 20   11 : 17 : 31  INFO mapred.JobClient:  map  100 %  reduce  100 %
08 / 11 / 20   11 : 17 : 32  INFO mapred.JobClient: Job complete: job_200811191041_0015

 

我想找到这个问题的所在了。是secondary name node所在的机器没有配置dfs.http.address这个参数,该参数在hadoop-default.xml里的缺省值是0.0.0.0:50070,应改为name node所在机器的ip地址。参考链接

11. 一些参考链接。

http://hayesdavis.net/2008/06/14/running-hadoop-on-windows/
http://hi.baidu.com/shirdrn/blog/category/Hadoop
http://www.ibm.com/developerworks/cn/opensource/os-cn-hadoop1/index.html
http://blog.ring.idv.tw/comment.ser?i=231

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值