hbase避坑:Hadoop 的 NameNode 找不到指定的存储目录

由于把 HBase/Hadoop 移到了 F 盘 ------ 而 Hadoop 的配置文件里还残留着旧的 C 盘路径,导致启动时仍去 C 盘找目录,而非实际的 F 盘路径。修正配置并完成 HDFS 格式化(必须步骤),解决这个目录不一致的问题。

一、错误原因分析

配置文件路径未更新:Hadoop 的hdfs-site.xml中配置的dfs.namenode.name.dir(NameNode 存储目录)、dfs.datanode.data.dir(DataNode 存储目录)还是旧的 C 盘路径,未同步到 F 盘;

未格式化 HDFS:即使改了配置,新的存储目录也需要先执行hdfs namenode -format格式化,否则 NameNode 无法识别新目录。

二、分步解决方法

步骤 1:修改 Hadoop 核心配置文件(更新路径到 F 盘)

打开F:\hbase\hadoop\etc\hadoop目录下的 2 个关键配置文件,修正路径:

  1. 修改core-site.xml(确认默认文件系统路径)
    确保fs.defaultFS是本地localhost,无路径错误:
    xml
    fs.defaultFS hdfs://localhost:9000 hadoop.tmp.dir F:/hbase/hadoop/tmp
  2. 修改hdfs-site.xml(核心:更新存储目录到 F 盘) 重点修正 NameNode 和 DataNode 的存储路径,替换旧的 C 盘路径: xml dfs.namenode.name.dir F:/hbase/hadoop/data/dfs/namenode dfs.datanode.data.dir F:/hbase/hadoop/data/dfs/datanode dfs.replication 1 dfs.permissions.enabled false 步骤 2:手动创建配置中指定的目录 Hadoop 不会自动创建存储目录,需手动新建以下文件夹(按配置路径): F:\hbase\hadoop\tmp F:\hbase\hadoop\data\dfs\namenode F:\hbase\hadoop\data\dfs\datanode 步骤 3:格式化 HDFS(关键!必须执行) 新目录创建后,需格式化 NameNode(仅第一次执行,重复执行会清空数据): 以管理员身份打开 CMD,进入 Hadoop 的 bin 目录: cmd cd F:\hbase\hadoop\bin 执行格式化命令: cmd hdfs.cmd namenode -format 执行成功的标志:最后输出Exiting with status 0(而非 1); 若提示Permission denied,确认是管理员 CMD,且目录有读写权限。 步骤 4:重新启动 HDFS 格式化完成后,按之前的方法启动 HDFS(手动启动更稳妥): 启动 NameNode: cmd cd F:\hbase\hadoop\bin hadoop.cmd namenode 此时日志会显示加载 F 盘目录,不再报错 "directory does not exist"。 新打开管理员 CMD,启动 DataNode: cmd cd F:\hbase\hadoop\bin hadoop.cmd datanode 步骤 5:验证 HDFS 启动成功 执行jps,能看到NameNode、DataNode进程,说明 HDFS 启动正常。 三、启动 HBase(此时路径一致,可正常启动) HDFS 启动成功后,进入 HBase 的 bin 目录执行: cmd cd F:\hbase\hbase\bin start-hbase.cmd 此时 HBase 会读取 F 盘的 HDFS 路径,不会再出现类加载或目录找不到的错误。 总结 核心原因:Hadoop 配置文件残留 C 盘旧路径,且新路径未格式化; 解决关键:① 修改core-site.xml/hdfs-site.xml为 F 盘路径;② 手动创建目录;③ 执行hdfs namenode -format格式化; 重要提醒:格式化仅第一次执行,若后续改路径需重新格式化(会清空数据)。
相关推荐
XDHCOM13 小时前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜13 小时前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage13 小时前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn13 小时前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜14 小时前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick199314 小时前
SQL 执行流程
数据库·sql
M--Y14 小时前
Redis常用数据类型
数据结构·数据库·redis
猿小喵14 小时前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
武子康14 小时前
大数据-263 实时数仓-Canal 增量订阅与消费原理:MySQL Binlog 数据同步实践
大数据·hadoop·后端
Y0011123615 小时前
MySQL-进阶
开发语言·数据库·sql·mysql