问题描述:
root@slave3:/home/hadoop/sqoop/sqoop# ./bin/sqoop import --connect jdbc:mysql://192.168.1.2:3306/hadoop --username root --password 1234 --table test
Error: /usr/lib/hadoop does not exist!Please set $HADOOP_COMMON_HOME to the root of your Hadoop installation.
分析:sqoop的导入导出,其实就是mapreduce的过程,这就必然需要用到YARN,要用到hadoop。如果sqoop连hadoop的安装目录都不知道,那就只能抓瞎了。并且根据错误提示可以推出, /usr/lib/hadoop可能是sqoop中HADOOP_COMMON_HOME默认配置的hadoop安装路径,所以必然需要修改sqoop配置。进入sqoop/conf目录,可以在sqoop-env-template.sh中发现有HADOOP_COMMON_HOME。
解决方法:先将sqoop-env-template.sh文件复制为sqoop-env.sh,修改里面的HADOOP_COMMON_HOME为hadoop安装路径:/home/hadoop/hadoop/hadoop-2.2.0/