HDFS的Shell操作

1.基本语法

bin/hadoop fs 具体命令 OR bin/hdfs dfs 具体命令
dfs是fs的实现类。

前期准备

.xml文件配置成功,节点都开启

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

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -help rm

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

用法1:hadoop fs -ls /
功能:列出hdfs文件系统根目录下的目录和文件
用法2:hadoop fs -ls -R /
功能:列出hdfs文件系统所有的目录和文件

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -ls /

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

用法1:hadoop fs -mkdir
功能:只能一级一级的建目录,父目录不存在的话使用这个命令会报错
用法2:hadoop fs -mkdir -p
功能:所创建的目录如果父目录不存在就创建该父目录

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -mkdir -p /sanguo/shuguo

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

用法:hadoop fs -moveFromLocal
功能:与put相类似,命令执行后源文件 local src 被删除

[jinghang@hadoop102 hadoop-2.7.2]$ touch kongming.txt
[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs  -moveFromLocal  ./kongming.txt  /sanguo/shuguo

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

用法:hadoop fs -appendToFile
功能:将一本地文件中的内容拼接在hdfs文件中

[jinghang@hadoop102 hadoop-2.7.2]$ touch liubei.txt
[jinghang@hadoop102 hadoop-2.7.2]$ vi liubei.txt

输入
san gu mao lu

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -appendToFile liubei.txt /sanguo/shuguo/kongming.txt

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

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -cat /sanguo/shuguo/kongming.txt

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

用法:hadoop fs -chown 用户名:组名
功能:修改文件或目录所属用户和组,递归加参数-R,chmod

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs  -chmod  666  /sanguo/shuguo/kongming.txt
[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs  -chown  jinghang:jinghang   /sanguo/shuguo/kongming.txt

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

用法:hadoop fs -copyFromLocal
功能:与put相类似

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -copyFromLocal README.txt /

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

用法:hadoop fs -copyToLocal
功能:与get相类似

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -copyToLocal /sanguo/shuguo/kongming.txt ./

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

用法:hadoop fs -cp
功能:目标文件不能存在,否则命令不能执行,相当于给文件重命名并保存,源文件还存在

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -cp /sanguo/shuguo/kongming.txt /zhuge.txt

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

用法:hadoop fs -mv
功能:目标文件不能存在,否则命令不能执行,相当于给文件重命名并保存,源文件不存在

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -mv /zhuge.txt /sanguo/shuguo/

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

用法:hadoop fs -get
功能:local file不能和 hdfs file名字不能相同,否则会提示文件已存在,没有重名的文件会复制到本地

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -get /sanguo/shuguo/kongming.txt ./

(13)-getmerge:合并下载多个文件,比如HDFS的目录

/user/jinghang/test下有多个文件:log.1, log.2,log.3,…

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -getmerge /user/jinghang/test/* ./zaiyiqi.txt

(14)-put:等同于copyFromLocal

用法:hadoop fs -put
功能:hdfs file的父目录一定要存在,否则命令不会执行

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -put ./zaiyiqi.txt /user/jinghang/test/

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

用法:hadoop fs -tail
功能:查看大文件后10行

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -tail -f /sanguo/shuguo/kongming.txt

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

用法1:hadoop fs -rm
功能:删除文件
用法2:hadoop fs -rm -r
功能:删除目录

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -rm /user/jinghang/test/jinlian2.txt

(17)-rmdir:删除空目录

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -mkdir /test
[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -rmdir /test

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

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -du -s -h /user/jinghang/test
2.7 K  /user/jinghang/test
[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -du  -h /user/jinghang/test
1.3 K  /user/jinghang/test/README.txt
15     /user/jinghang/test/jinlian.txt
1.4 K  /user/jinghang/test/zaiyiqi.txt

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

[jinghang@hadoop102 hadoop-2.7.2]$ hadoop fs -setrep 10 /wcinput/input.txt
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HDFS Shell是Hadoop分布式文件系统的命令行工具,用于管理HDFS文件目录。以下是HDFS Shell常用的一些操作: 1. 列出目录文件目录:`hdfs dfs -ls <目录路径>` 2. 创建目录:`hdfs dfs -mkdir <目录路径>` 3. 删除目录:`hdfs dfs -rm -r <目录路径>` 4. 上传本地文件HDFS:`hdfs dfs -put <本地文件路径> <HDFS目录路径>` 5. 下载HDFS文件到本地:`hdfs dfs -get <HDFS文件路径> <本地目录路径>` 6. 合并HDFS文件到本地:`hdfs dfs -getmerge <HDFS目录路径> <本地文件路径>` 7. 复制文件:`hdfs dfs -cp <源文件路径> <目标文件路径>` 8. 移动文件:`hdfs dfs -mv <源文件路径> <目标文件路径>` 9. 查看文件内容:`hdfs dfs -cat <文件路径>` 10. 修改文件权限:`hdfs dfs -chmod <权限> <文件路径>` 以上是HDFS Shell的一些常用操作,可以帮助用户管理Hadoop分布式文件系统文件目录。 ### 回答2: Hadoop分布式文件系统(Hadoop Distributed File System,简称HDFS)是Apache Hadoop的核心组件之一,用于存储和处理大规模数据集。HDFS Shell是Hadoop提供的基于命令行的操作工具,用于执行文件系统的管理操作HDFS Shell主要提供以下操作: 1. 文件目录操作: - ls:列出指定目录下的内容。 - mkdir:创建一个新目录。 - rm:删除指定文件目录。 - mv:将文件目录移动到新位置。 - chmod:修改文件目录的权限设置。 2. 文件上传和下载: - put:上传本地文件HDFS。 - get:将HDFS上的文件下载到本地。 3. HDFS文件操作: - cat:打印文件内容。 - tail:打印文件的结尾部分。 - head:打印文件的开头部分。 - du:计算文件目录的大小。 - count:统计指定目录文件以及目录的个数。 - checksum:计算文件内容的检验和。 4. 其他操作: - help:列出所有可用命令。 - usage:显示指定命令的使用方法信息。 - exit:退出HDFS Shell。 使用HDFS Shell进行操作时,可以根据需要选择合适的命令来执行对应的操作。例如,使用ls命令可以列出指定目录下的文件目录,使用put命令可以上传本地文件HDFS,使用cat命令可以打印指定文件的内容等。 HDFS Shell操作也可以通过Shell脚本来批量执行,可以更加方便地进行文件系统管理。总的来说,HDFS Shell是一种方便、高效的文件系统操作工具,对于Hadoop用户来说是必不可少的。 ### 回答3: HDFS(Hadoop 分布式文件系统)是一个由 Apache Hadoop 提供的分布式文件存储系统。HDFS ShellHDFS 文件系统的命令行接口,可以通过命令行终端进行 HDFS 文件系统的操作,实现文件的上传、下载、创建等。 HDFS Shell 使用方式如下: 1. 进入 Hadoop 环境,输入命令`hdfs dfs`或`hadoop fs`后,就可以使用 HDFS Shell。 2. 命令格式: ``` hadoop fs [通用选项] [-D <属性>=<值>] <命令> [命令选项] ``` 表示 HDFS Shell 包含的通用选项、属性选项,以及命令和命令选项。 其,通用选项包括 `-conf`、`-D`、`-fs`、`-jt` 等,这些选项在 Hadoop 的其他模块也可以使用。 命令包括 `cat`、`cp`、`count`、`get`、`ls`、`mkdir`、`mv`、`put`、`rm`、`rmdir` 等。 命令选项包括 `-skipTrash`、`-skipChecksum`、`-overwrite`、`-recursive` 等。 3. HDFS Shell 常用命令: `ls`:显示 HDFS 目录下的文件目录。 `mkdir`:在 HDFS 创建一个新的目录。 `put`:将本地文件目录上传到 HDFS 文件系统。 `get`:将 HDFS 文件系统文件目录下载到本地。 `rm`:删除 HDFS 文件系统文件目录。 `mv`:将 HDFS 文件系统文件目录移动到另一个位置。 4. HDFS Shell 实例: `hdfs dfs -ls /`:列出 HDFS 根目录下的文件目录。 `hdfs dfs -mkdir /test`:在 HDFS 创建一个名为 test 的目录。 `hdfs dfs -put localfile /test`:将本地文件 localfile 上传到 HDFS目录 test 。 `hdfs dfs -get /test/hadoopfile localfile`:将 HDFS test 目录下的文件 hadoopfile 下载到本地的 localfile 。 `hdfs dfs -rm /test/hadoopfile`:删除 HDFS test 目录下的文件 hadoopfile。 `hdfs dfs -mv /test/hadoopfile /test/newfile`:将 HDFS test 目录下的文件 hadoopfile 移动到 test 目录下的 newfile 。 综上所述,HDFS Shell 对于 Hadoop 分布式文件系统的管理和维护具有很重要的意义,能够方便地进行文件的上传、下载、删除、创建操作。此外,HDFS Shell 还支持批量处理和脚本编程,可以方便地实现批量操作,提高操作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值