常用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 文件系统的应用场景,提升开发和运维效率。

相关推荐
武子康2 小时前
大数据-34 HBase 单节点配置 hbase-env hbase-site xml
大数据·后端·hbase
Edingbrugh.南空2 小时前
Hadoop MapReduce 入门
大数据·hadoop·mapreduce
huisheng_qaq3 小时前
【ElasticSearch实用篇-01】需求分析和数据制造
大数据·elasticsearch·制造
G.E.N.3 小时前
开源!RAG竞技场(2):标准RAG算法
大数据·人工智能·深度学习·神经网络·算法·llm·rag
勤奋的知更鸟4 小时前
Kettle + 大数据实战:从数据采集到分布式处理的完整流程指南
大数据·分布式
鸭鸭鸭进京赶烤11 小时前
大学专业科普 | 云计算、大数据
大数据·云计算
G皮T15 小时前
【Elasticsearch】自定义评分检索
大数据·elasticsearch·搜索引擎·查询·检索·自定义评分·_score
搞笑的秀儿18 小时前
信息新技术
大数据·人工智能·物联网·云计算·区块链
SelectDB18 小时前
SelectDB 在 AWS Graviton ARM 架构下相比 x86 实现 36% 性价比提升
大数据·架构·aws
二二孚日19 小时前
自用华为ICT云赛道Big Data第五章知识点-Flume海量日志聚合
大数据·华为