hadoop的一些常见问题及解决方法

第一个问题是:


当启动hadoop时,会报如下错误:


starting namenode, logging to /home/june/hadoop-0.21.0/bin/../logs/hadoop-root-namenode-june-bjtu.out


localhost: Error: JAVA_HOME is not set.


localhost: Error: JAVA_HOME is not set.


starting jobtracker, logging to /home/june/hadoop-0.21.0/bin/../logs/hadoop-root-jobtracker-june-bjtu.out


localhost: Error: JAVA_HOME is not set.


解决办法是:


在hadoop-0.21.0/conf/文件夹里有个hadoop-env.sh的文件,它的作用是配置与hadoop运行环境相关的变量,其中有一个变量是JAVA_HOME,将它修改为你安装java的路径。具体操作如下:


vim hadoop-env.sh


# The java implementation to use.  Required.


# export JAVA_HOME=/usr/lib/j2sdk1.6-sun


export JAVA_HOME=/usr/lib/jvm/java-6-openjdk



第二个问题是:


执行java程序时要先编译成class文件,才能用hadoop命令,但是编译的时候会有如下错误:


javac FileSystemCat.java


FileSystemCat.java:3: package org.apache.hadoop.io does not exist


import org.apache.hadoop.io.*;



FileSystemCat.java:4: package org.apache.hadoop.conf does not exist


import org.apache.hadoop.conf.*;



FileSystemCat.java:5: package org.apache.hadoop.fs does not exist


import org.apache.hadoop.fs.*;


解决办法是:


这是一个纯java问题啦,具体解决办法有:


javac -classpath "/home/june/hadoop-0.21.0/hadoop-common-0.21.0.jar"  FileSystemCat.java


或者


export CLASSPATH=.:/home/june/hadoop-0.21.0/hadoop-common-0.21.0.jar:$CLASSPATH


还有就是,书上说的程序没有说那些类所在的包,所以自己要查查API。



第三个问题是:


执行读文件的程序时会报如下错误:


hadoop FileSystemCat hdfs://localhost/user/june/quangle.txt


Exception in thread "main" java.lang.NoClassDefFoundError: FileSystemCat


Caused by: java.lang.ClassNotFoundException: FileSystemCat


        at java.net.URLClassLoader$1.run(URLClassLoader.java:217)


        at java.security.AccessController.doPrivileged(Native Method)


        at java.net.URLClassLoader.findClass(URLClassLoader.java:205)


        at java.lang.ClassLoader.loadClass(ClassLoader.java:321)


        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)


        at java.lang.ClassLoader.loadClass(ClassLoader.java:266)


Could not find the main class: FileSystemCat. Program will exit.


解决办法是:


熟悉java的人肯定知道是因为没有设置classpath,在hadoop环境下怎么设置classpath呢?同样也是修改hadoop-0.21.0/conf/文件夹里的hadoop-env.sh文件,具体操作如下:


# Extra Java CLASSPATH elements.  Optional.


# export HADOOP_CLASSPATH=


export HADOOP_CLASSPATH=.


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值