常用Hadoop HDFS命令详解与实用指南

Hadoop HDFS(分布式文件系统)通过命令行工具提供了丰富的文件管理功能。使用 hadoop fs 命令可以方便地操作 HDFS 文件和目录,类似于 Linux 系统的文件管理命令。本文将围绕常用的 HDFS 操作命令进行详细讲解,并用实例展示实用技巧,帮助你快速上手。

基本命令结构理解

所有 HDFS 文件操作命令均以 hadoop fs 开头,例如:

  • hadoop fs -ls 用于列出目录内容
  • hadoop fs -mkdir 用于创建目录
  • hadoop fs -cat 用于查看文件内容

这个结构类似于 Linux 命令,hadoop fs 相当于执行文件系统的操作入口。

查看目录与文件内容

列出目录下的文件和目录

bash 复制代码
hadoop fs -ls /path/to/directory

此命令显示指定路径(如果省略,则默认当前用户的 HDFS 根目录)下所有文件和目录的详细信息,包括权限、拥有者、大小和修改时间。

读取并输出文件内容

bash 复制代码
hadoop fs -cat /path/to/file.txt

将指定文件的内容直接输出到终端,方便实时查看文件数据。

目录和文件管理

创建目录

bash 复制代码
hadoop fs -mkdir /path/to/new_directory

在指定路径下创建新目录。可以多级创建,但需要确保父目录存在。

上传本地文件至 HDFS

bash 复制代码
hadoop fs -put /local/path/file.txt /hdfs/path/

将本地文件上传到 HDFS 指定目录。命令也支持上传文件夹。

下载文件或目录到本地

bash 复制代码
hadoop fs -get /hdfs/path/file_or_dir /local/path/

将 HDFS 上的文件或目录下载到本地指定位置。

合并文件并下载(getmerge)

Hadoop 作业输出通常是分布式多个 part- 文件,-getmerge 命令可将这些文件合并成为一个本地文件。

bash 复制代码
hadoop fs -getmerge /hdfs/path/dir /local/path/merged_file.txt

所有 part- 文件会依次合并输出到本地文件中。

合并时文件间加空行

加上 -nl 参数,合并的各个文件内容之间会自动插入换行,方便区分:

bash 复制代码
hadoop fs -getmerge -nl /hdfs/path/dir /local/path/merged_file.txt

查看文件和目录信息

统计文件和子目录数量

bash 复制代码
hadoop fs -count /hdfs/path/dir

显示目录下的目录数量、文件数量和文件总大小(单位为字节),有助于了解存储结构和容量。

查看文件或目录大小

bash 复制代码
hadoop fs -du /hdfs/path/file_or_dir

显示指定路径下所有文件的大小列表,若指定为单个文件,则显示该文件大小。可以用来判断文件占用空间情况。

删除文件和目录

删除文件

bash 复制代码
hadoop fs -rm /hdfs/path/file

删除指定文件,操作谨慎,通常会移动至回收站(Trash)。

删除目录

bash 复制代码
hadoop fs -rmr /hdfs/path/directory

递归删除目录及其所有内容。

注意: 删除操作不可逆,建议确认路径正确,误删后可尝试从 Trash 恢复。

其他实用提示

  • 输入 hadoop 命令可以查看 Hadoop 的安装路径及环境配置信息。
  • 多使用 hadoop fs -help 查看所有支持的文件系统命令及其用法。
  • 结合 Shell 脚本自动化操作可提升工作效率,如定时清理旧数据、批量上传下载等。

通过熟练掌握以上 HDFS 命令,您可以高效地管理大数据存储,便利地完成文件上传、查看、下载和删除等核心操作。希望本指南能够帮助您快速启动 Hadoop 文件系统的应用场景,提升开发和运维效率。

相关推荐
SelectDB13 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
ApacheSeaTunnel16 小时前
当多表数据涌入,Apache SeaTunnel 如何巧妙化解主键冲突?
大数据·开源·数据集成·seatunnel·技术分享·数据同步
大大大大晴天4 天前
Hudi Metadata Table 与 Hive Sync (HMS)怎么选?
大数据
手可摘星辰7774 天前
一次线上FlinkCDC异常排查复盘
大数据·flink
大大大大晴天4 天前
Hudi技术内幕:Metadata Table原理与实践
大数据
大大大大晴天5 天前
Hudi技术内幕:深入解析Index索引机制
大数据
阿里云大数据AI技术5 天前
Flink Forward Asia 2026 深圳启幕:Agentic Streaming for AI,开启实时智能新范式
大数据·flink
SelectDB6 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
大大大大晴天9 天前
Hudi技术内幕:RecordPayload到RecordMerger
大数据
SelectDB10 天前
秒级弹性、最高降本 70%:SelectDB Serverless 如何重塑云数仓资源效率
大数据·后端·云原生