hadoop mapreduce 出现 /bin/bash: /bin/java: No such file or directory

执行MapReduce程序报错,提示/bin/java无法执行。原因是找不到该文件,需创建一个指向JDK真实目录的软连接。在shell终端执行相应命令创建软连接后,命令可运行。若Hadoop是集群环境,需在每台机器上创建,之后再执行程序就不会报错。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

执行MapReduce 程序的时候报错,如下

2019-07-12 00:51:53,868 INFO mapreduce.Job: Task Id : attempt_1562862697087_0005_m_000003_1001, Status : FAILED
[2019-07-12 00:51:52.484]Exception from container-launch.
Container id: container_1562862697087_0005_02_000011
Exit code: 127

[2019-07-12 00:51:52.490]Container exited with a non-zero exit code 127. Error file: prelaunch.err.
Last 4096 bytes of prelaunch.err :
Last 4096 bytes of stderr :
/bin/bash: /bin/java: No such file or directory
 

很好理解 /bin/java 无法执行

在shell 终端执行  /bin/java   无法执行

需要创建一个/bin/java 的软连接  实际指向  jdk 真实目录

我的jdk真实目录是 /usr/local/jdk1.8.0_112/

所以在shell 终端执行 

ln -s /usr/local/jdk1.8.0_112/bin/java /bin/java

再执行  /bin/java 

发现命令可以运行

如果hadoop是集群环境,需要在每台机器上创建软连接

再执行 MapReduce程序 就不会报错了

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值