【在 Windows 上运行 Apache Hadoop 或 Spark/GeoTrellis 涉及 HDFS 】

在 Windows 上运行 Apache Hadoop 或 Spark/GeoTrellis 涉及 HDFS 或文件系统操作时的经典问题

您遇到的错误是 在 Windows 上运行 Apache Hadoop 或 Spark/GeoTrellis 涉及 HDFS 或文件系统操作时的经典问题

错误信息 java.io.FileNotFoundException: Could not locate Hadoop executable: C:\Users\Patch\AppData\Local\Temp\bin\winutils.exe 非常明确地指出了问题所在。

这是因为您的 GeoTrellis/Spark 代码在执行 FileSystem.get(sc.hadoopConfiguration).mkdirs(outputDir) 等操作时,底层调用了 Hadoop 的文件系统 API。在 Windows 环境下,Hadoop 需要一个名为 winutils.exe 的特殊工具来模拟 Linux 的文件权限和操作,但它无法在您的临时目录中找到该文件。


解决方案:配置 winutils.exe

解决此问题的标准且最简单的方法是下载正确的 Hadoop Windows 二进制文件,并配置您的系统或 Spark 应用程序指向它们。

步骤 1: 下载 winutils.exe

您需要下载与您使用的 Hadoop 版本 兼容的 winutils.exe 和相关二进制文件。

  1. 确定 Hadoop 版本: 检查您的 Spark 或 GeoTrellis 依赖中使用的 Hadoop 版本(例如,通常是 Hadoop 2.7.x 或 3.x)。
  2. 下载二进制文件: 搜索并下载对应版本的 Hadoop Windows 二进制文件包。
    • 一个常用的资源是 steveloughran/winutils 的 GitHub 仓库,其中包含了常见版本的编译好的二进制文件。

步骤 2: 创建本地 Hadoop 目录

在您的本地文件系统上创建一个专用的目录来存放这些文件。

  1. 创建一个目录,例如:C:\hadoop\bin
  2. 将下载的 winutils.exehadoop.dll(如果存在)放到 C:\hadoop\bin 目录下。

步骤 3: 配置 Spark/Hadoop 环境变量

您可以通过两种方式告诉 Spark/Hadoop 您的 winutils.exe 在哪里:

选项 A (推荐): 设置系统环境变量

这是最彻底的解决方案,对所有 Spark 应用都有效。

  1. 设置 HADOOP_HOME 环境变量:

    • 变量名: HADOOP_HOME
    • 变量值: C:\hadoop (指向您创建的根目录,不是 bin 目录)
  2. 更新 Path 环境变量:

    • %HADOOP_HOME%\bin 添加到您的系统 Path 环境变量中。
选项 B: 运行时配置 SparkContext

如果您无法修改系统环境变量,可以在代码中配置 Spark 运行时。您需要在创建 SparkContext 之前设置 Hadoop 配置。

在您的测试代码或初始化 SparkContext 的地方(例如 SparkTestBase 或您的 main 函数),添加以下代码:

scala 复制代码
// 导入 Hadoop Configuration
import org.apache.hadoop.conf.Configuration

// 在创建 SparkContext 之前执行此操作
val hadoopHomeDir = "C:\\hadoop" // 替换为您 winutils.exe 所在的根目录

System.setProperty("hadoop.home.dir", hadoopHomeDir)

// (如果您的程序已经创建了 SparkContext,则可以直接配置)
// val conf = new Configuration()
// conf.set("fs.file.impl", classOf[org.apache.hadoop.fs.LocalFileSystem].getName)
// conf.set("fs.hdfs.impl", classOf[org.apache.hadoop.hdfs.DistributedFileSystem].getName)

// ... 正常创建 SparkContext
// implicit val sc: SparkContext = new SparkContext(...)

总结和快速检查

完成设置后,请重启您的 IDE (IntelliJ IDEA, Eclipse 等),以便新的环境变量生效。

检查项 值/路径 目的
HADOOP_HOME C:\hadoop 指向 Hadoop 根目录
%HADOOP_HOME%\bin C:\hadoop\bin 包含 winutils.exe
winutils.exe 位于 C:\hadoop\bin 允许 Hadoop 在 Windows 上执行文件权限操作

解决这个 winutils.exe 缺失的问题后,您的 Spark/GeoTrellis 代码就应该能够成功创建本地文件系统中的目录(如 test/png_pyramid_test/png_test_layer)并继续执行后续的瓦片生成和保存操作了。

相关推荐
深圳市恒讯科技22 分钟前
英国服务器Windows系统远程桌面安装与优化
运维·服务器·windows
像风一样的男人@1 小时前
python --两个文件夹文件名比对(yolo 图和label标注比对检查)
windows·python·yolo
diannao7205 小时前
实时将大模型的解决方案转换为随机应变的机器人指令
开发语言·windows·python·机器人
奔跑吧邓邓子5 小时前
【C语言实战(75)】C语言内存探秘:泄漏检测与分析实战
linux·c语言·windows·内存·开发实战·泄露检测
A-刘晨阳12 小时前
时序数据库选型指南:从大数据视角切入,聚焦 Apache IoTDB
大数据·apache·时序数据库·iotdb
迦蓝叶13 小时前
使用 Apache Jena 构建 Java 知识图谱
java·apache·知识图谱·图搜索·关系查询·关系推理
刘恒12345678915 小时前
Windows 10 docker 配置(PHP+Nginx+Mysql)(thinkphp5项目)环境
windows·docker·php
苏比的博客18 小时前
Windows MFC添加类,变量,类导向
c++·windows·mfc
孫治AllenSun21 小时前
【算法】图相关算法和递归
windows·python·算法
TeleostNaCl1 天前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享