Hadoop中hdfs dfs 下的命令

本文介绍了 Hadoop 文件系统 (HDFS) 的一系列实用命令及其使用方法,包括文件和目录的操作,如创建、复制、移动、删除等,并通过实际操作示例展示了如何管理和维护 HDFS 中的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

命令大全

[-appendToFile <localsrc> ... <dst>]

        [-cat [-ignoreCrc] <src> ...]

        [-checksum <src> ...]

        [-chgrp [-R] GROUP PATH...]

        [-chmod [-R] <MODE[,MODE]... | OCTALMODE> PATH...]

        [-chown [-R] [OWNER][:[GROUP]] PATH...]

        [-copyFromLocal [-f] [-p] <localsrc> ... <dst>]

        [-copyToLocal [-p] [-ignoreCrc] [-crc] <src> ... <localdst>]

        [-count [-q] <path> ...]

        [-cp [-f] [-p] <src> ... <dst>]

        [-createSnapshot <snapshotDir> [<snapshotName>]]

        [-deleteSnapshot <snapshotDir> <snapshotName>]

        [-df [-h] [<path> ...]]

        [-du [-s] [-h] <path> ...]

        [-expunge]

        [-get [-p] [-ignoreCrc] [-crc] <src> ... <localdst>]

        [-getfacl [-R] <path>]

        [-getmerge [-nl] <src> <localdst>]

        [-help [cmd ...]]

        [-ls [-d] [-h] [-R] [<path> ...]]

        [-mkdir [-p] <path> ...]

        [-moveFromLocal <localsrc> ... <dst>]

        [-moveToLocal <src> <localdst>]

        [-mv <src> ... <dst>]

        [-put [-f] [-p] <localsrc> ... <dst>]

        [-renameSnapshot <snapshotDir> <oldName> <newName>]

        [-rm [-f] [-r|-R] [-skipTrash] <src> ...]

        [-rmdir [--ignore-fail-on-non-empty] <dir> ...]

        [-setfacl [-R] [{-b|-k} {-m|-x <acl_spec>} <path>]|[--set <acl_spec> <path>]]

        [-setrep [-R] [-w] <rep> <path> ...]

        [-stat [format] <path> ...]

        [-tail [-f] <file>]

        [-test -[defsz] <path>]

        [-text [-ignoreCrc] <src> ...]

        [-touchz <path> ...]

        [-usage [cmd ...]]

3.常用命令实操

(0)启动Hadoop集群(方便后续的测试) 

sbin/start-dfs.sh
sbin/start-yarn.sh

(1)-help:输出这个命令参数

   

hadoop fs -help rm

(2)-ls: 显示目录信息

 

  hadoop fs -ls /

(3)-mkdir:在HDFS上创建目录

 hadoop fs -mkdir -p /sanguo/shuguo

(4)-moveFromLocal:从本地剪切粘贴到HDFS 

touch kongming.txt

hadoop fs  -moveFromLocal  ./kongming.txt  /sanguo/shuguo

(5)-appendToFile:追加一个文件到已经存在的文件末尾

touch liubei.txt

 vi liubei.txt

输入:san gu mao lu

hadoop fs -appendToFile liubei.txt /sanguo/shuguo/kongming.txt

(6)-cat:显示文件内容

hadoop fs -cat /sanguo/shuguo/kongming.txt

(7)-chgrp 、-chmod、-chown:Linux文件系统中的用法一样,修改文件所属权限

(8)-copyFromLocal:从本地文件系统中拷贝文件到HDFS路径去

hadoop fs -copyFromLocal README.txt /

(9)-copyToLocal:从HDFS拷贝到本地

 hadoop fs -copyToLocal /sanguo/shuguo/kongming.txt ./

(10)-cp :从HDFS的一个路径拷贝到HDFS的另一个路径

hadoop fs -cp /sanguo/shuguo/kongming.txt /zhuge.txt

(11)-mv:在HDFS目录中移动文件

 hadoop fs -mv /zhuge.txt /sanguo/shuguo/

(12)-get:等同于copyToLocal,就是从HDFS下载文件到本地

 hadoop fs -get /sanguo/shuguo/kongming.txt ./

(13)-getmerge:合并下载多个文件,比如HDFS的目录 /user/atguigu/test下有多个文件:log.1, log.2,log.3,...

 hadoop fs -getmerge /user/atguigu/test/* ./zaiyiqi.txt

(14)-put:等同于copyFromLocal

hadoop fs -put ./zaiyiqi.txt /user/atguigu/test/

(15)-tail:显示一个文件的末尾

 hadoop fs -tail /sanguo/shuguo/kongming.txt

(16)-rm:删除文件或文件夹

 

hadoop fs -rm /user/atguigu/test/jinlian2.txt

(17)-rmdir:删除空目录

hadoop fs -mkdir /test

hadoop fs -rmdir /test

(18)-du统计文件夹的大小信息

 hadoop fs -du -s -h /user/atguigu/test

2.7 K  /user/atguigu/test



 hadoop fs -du  -h /user/atguigu/test

1.3 K  /user/atguigu/test/README.txt

15     /user/atguigu/test/jinlian.txt

1.4 K  /user/atguigu/test/zaiyiqi.txt

(19)-setrep:设置HDFS中文件的副本数量

 

hadoop fs -setrep 10 /sanguo/shuguo/kongming.txt

 

### Hadoop HDFS Shell 命令集合 以下是 Hadoop HDFS 中常用的 Shell 命令列表: #### 文件操作类命令 1. **上传文件HDFS** - 使用 `copyFromLocal` 或 `put` 将本地文件复制到 HDFS 上。 ```bash hadoop fs -copyFromLocal [本地地址] [hadoop目录] hadoop fs -put [本地地址] [hadoop目录] ``` 这两个命令功能相同,均用于将数据从本地文件系统传输至 HDFS[^1]。 2. **下载文件到本地** - 使用 `get` 或 `copyToLocal` 将 HDFS 文件下载到本地。 ```bash hadoop fs -get [hdfs路径] [本地地址] hadoop fs -copyToLocal [hdfs路径] [本地地址] ``` 3. **查看文件内容** - 查看 HDFS 文件的内容。 ```bash hadoop fs -cat [hdfs路径] ``` 4. **显示部分文件内容** - 显示文件开头部分内容(类似于 Linux 的 head 命令)。 ```bash hadoop fs -head [hdfs路径] ``` 5. **删除文件目录** - 删除单个文件或整个目录。 ```bash hadoop fs -rm [hdfs路径] hadoop fs -rm -r [hdfs路径] ``` 6. **移动文件** - 移动文件位置或将文件重命名。 ```bash hadoop fs -mv [源路径] [目标路径] ``` 7. **创建空白文件** - 创建个新的空文件(不推荐使用此方法)。 ```bash hadoop fs -touchz [hdfs路径] ``` #### 目录操作类命令 1. **创建目录** - 在 HDFS 上创建新目录。 ```bash hadoop fs -mkdir -p [hdfs路径] ``` 2. **列出目录内容** - 列出指定目录下的所有文件子目录。 ```bash hadoop fs -ls [hdfs路径] ``` 3. **更改权限** - 修改文件目录的访问权限。 ```bash hadoop fs -chmod [权限模式] [hdfs路径] ``` 4. **更改所有权** - 更改文件目录的所有者。 ```bash hadoop fs -chown [用户名[:组名]] [hdfs路径] ``` #### 配置与状态查询类命令 1. **设置副本数量** - 设置 HDFS 文件的副本数量。 ```bash hadoop fs -setrep [-w] <副本数> <hdfs路径> ``` 如果需要递归地应用到目录中的所有文件,则加上 `-R` 参数[^2]。 2. **统计磁盘空间** - 统计当前目录及其子目录占用的空间大小。 ```bash hadoop fs -du -s -h [hdfs路径] ``` 3. **检查文件健康状况** - 检查 HDFS 文件的状态并报告损坏情况。 ```bash hadoop fsck [hdfs路径] ``` 4. **显示配置信息** - 展示客户端连接到 NameNode DataNodes 的详细信息。 ```bash hadoop fs -stat [hdfs路径] ``` #### 集群管理类命令 1. **启动/停止集群服务** - 启动或关闭 HDFS YARN 服务。 ```bash sbin/start-dfs.sh sbin/start-yarn.sh sbin/stop-dfs.sh sbin/stop-yarn.sh ``` 2. **单独控制节点进程** - 单独启停 NameNode/Datanode 或 ResourceManager/Nodemanager。 ```bash sbin/hadoop-daemon.sh start namenode sbin/hadoop-daemon.sh stop datanode sbin/yarn-daemon.sh start resourcemanager sbin/yarn-daemon.sh stop nodemanager ``` --- ### 注意事项 - 当执行某些敏感操作时可能会遇到错误提示。例如,在尝试调整副本策略时,需确认 `hdfs-site.xml` 是否已正确配置替换策略属性[^5]。 ```xml <property> <name>dfs.client.block.write.replace-datanode-on-failure.policy</name> <value>NEVER</value> </property> ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值