Error: JAVA_HOME is incorrectly set. Please update C:\hadoop-2.5.1\conf\hadoop-env.cmd ‘

简介: Error: JAVA_HOME is incorrectly set. Please update C:\hadoop-2.5.1\conf\hadoop-env.cmd ‘

报错显示


  有些同学在Windows下解压安装好Hadoop后执行hadoop version命令报错了,报错信息如下:

The system cannot find the path specified.
Error: JAVA_HOME is incorrectly set.
Please update C:\hadoop-2.5.1\conf\hadoop-env.cmd '-Xmx512m' is not recognized as an internal or external command, ooperable program or batch file. 



错误原因


  这是因为在hadoop-env.cmd里面配置jdk路径时出错了,有以下两种可能:

  • 一是因为jdk路径错了。
  • 二是因为jdk的安装路径里面有空格,例如jdk直接安装在了Program Files文件夹里面。



解决办法


这里有三种解决办法:


   将jdk重新安装一下,安装目录不要有中文和空格这些特殊字符,然后重新设置jdk路径。步骤如下:


   1) 将JDK目录复制到C盘或者其他盘:C:\Java\ jdk1.8.0_40


   2)编辑 etc hadoop hadoop-env.cmd并更改:设置JAVA_HOME = C:\Java\ jdk1.8.0_40


   3)运行cmd并执行hadoop-env.cmd


   4)再检查" hadoop version"是否仍在报错


图片如下所示:



  1. 如果是安装在C盘的Program Files文件夹里面,可以采用cmd字符替代,如下所示:
Progra~1 = 'Program Files'
  Progra~2 = 'Program Files(x86)'



在hadoop-env.cmd中添加以下配置:


set JAVA_HOME=C:\Progra~1\Java\jdk1.8.0_40\

   要解决必须在没有空格的路径中安装另一个JDK的问题,可以使用Windows命令mklink创建符号链接。


   步骤如下:


   1)以管理员身份打开cmd提示符,创建符号链接。

     在这里,我将Hadoop报错的路径(带有Program Files)设置为一个没有空格的简单路径。 / D 参数表示正在创建目录符号链接。如下:

   mklink / D java_home" C: Program Files Java jdk1.7.0_65"


   2)在hadoop-env.cmd中,将JAVA_HOME设置为您创建的符号链接:

   设置JAVA_HOME = java_home



结语


每个人刚开始学习的时候都是小白,这个过程中或多或少的都会看看别人写的博客,过程中也可能会踩过很多坑。遇到问题的时候,我们可以记录下来,不管是对自己还是对其他学习的小伙伴都很有帮助。


程序员大多都是很孤独的,写作也可以让自己的孤独“有处安放”,多去表达,多点表达,对于不善言辞的程序员总是有很多好处,博文写作的过程中最重要的是思路清晰有条理,和敲代码最大的不同是,编程有了明确的目标,日复一日必成高手,而写作如果只是为了写而写,往往会失了初心,丢了本真。写作不仅可以提高言语表达能力,更可以培养持续做事情的毅力,最好得是能遇到很多志同道合的朋友。




相关文章
|
13天前
|
Java
Error:Internal error: (java.lang.IllegalAccessError) class com.,idea2019.3版本,必须用application2.7.6或者以下
Error:Internal error: (java.lang.IllegalAccessError) class com.,idea2019.3版本,必须用application2.7.6或者以下
|
15天前
|
分布式计算 Hadoop Java
优化大数据处理:Java与Hadoop生态系统集成
优化大数据处理:Java与Hadoop生态系统集成
|
13天前
|
Java
Error:java: 错误: 无效的源发行版:13, 类文件具有错误的版本 61.0, 应为 55.0 请删除该文件或确保该文件位于正确的类路径子目录中。
Error:java: 错误: 无效的源发行版:13, 类文件具有错误的版本 61.0, 应为 55.0 请删除该文件或确保该文件位于正确的类路径子目录中。
|
13天前
|
分布式计算 Hadoop 大数据
优化大数据处理:Java与Hadoop生态系统集成
优化大数据处理:Java与Hadoop生态系统集成
|
18天前
|
Java 数据库连接 数据库
Error:Internal error: (java.lang.NoClassDefFoundError) Could not initialize class com.intellij.util.
Error:Internal error: (java.lang.NoClassDefFoundError) Could not initialize class com.intellij.util.
|
18天前
|
Java Maven
Error:java: 错误: 不支持发行版本 5,请使用6或更高版本
Error:java: 错误: 不支持发行版本 5,请使用6或更高版本
|
21天前
|
Java
Intellij idea 报错:Error : java 不支持发行版本5
Intellij idea 报错:Error : java 不支持发行版本5
19 0
|
25天前
|
安全 前端开发 Java
Java Web项目登录报Session Error
Java Web项目登录报Session Error
19 0
|
1月前
|
分布式计算 Java Hadoop
简单的java Hadoop MapReduce程序(计算平均成绩)从打包到提交及运行
简单的java Hadoop MapReduce程序(计算平均成绩)从打包到提交及运行
26 0
|
1月前
|
Java 程序员 编译器
蓝易云 - Java:Exception和Error有什么区别?
总的来说,Exception和Error的主要区别在于他们的用途和处理方式。Exception是可以被程序员处理的问题,而Error则是程序无法处理的严重问题。在编写代码时,程序员应该尽力处理可能出现的异常,但是对于错误,除非你知道如何处理,否则最好让程序终止,因为继续运行可能会导致更严重的问题。
14 0