hadoop之 HDFS fs 命令总结
版本:Hadoop 2.7.4
-- 查看hadoop fs帮助信息
[root@hadp-master sbin]# hadoop fs
Usage: hadoop fs [generic options]
[-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] [-l] <localsrc> ... <dst>]
[-copyToLocal [-p] [-ignoreCrc] [-crc] <src> ... <localdst>]
[-count [-q] [-h] <path> ...]
[-cp [-f] [-p | -p[topax]] <src> ... <dst>]
[-createSnapshot <snapshotDir> [<snapshotName>]]
[-deleteSnapshot <snapshotDir> <snapshotName>]
[-df [-h] [<path> ...]]
[-du [-s] [-h] <path> ...]
[-expunge]
[-find <path> ... <expression> ...]
[-get [-p] [-ignoreCrc] [-crc] <src> ... <localdst>]
[-getfacl [-R] <path>]
[-getfattr [-R] {-n name | -d} [-e en] <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] [-l] <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>]]
[-setfattr {-n name [-v value] | -x name} <path>]
[-setrep [-R] [-w] <rep> <path> ...]
[-stat [format] <path> ...]
[-tail [-f] <file>]
[-test -[defsz] <path>]
[-text [-ignoreCrc] <src> ...]
[-touchz <path> ...]
[-truncate [-w] <length> <path> ...]
[-usage [cmd ...]]
注意:
- 以下指令均是在,Linux 命令行窗口界面操作。
- [ ]表示可选参数,<>表示必须参数。
- 开始使用命令前,必须启动Hadoop
(1)-appendToFile
用法: hadoop fs -appendToFile <localsrc> ... <dst>
作用:是将一个或者多个文件添加到HDFS系统中。
示例:
1
2
3
4
|
hadoop fs -appendToFile localfile /user/hadoop/hadoopfile hadoop fs -appendToFile localfile1 localfile2 /user/hadoop/hadoopfile hadoop fs -appendToFile localfile hdfs: //nn.example.com/hadoop/hadoopfile hadoop fs -appendToFile - hdfs: //nn.example.com/hadoop/hadoopfile Reads the input from stdin. |
(2)-cat
用法:hadoop fs -cat URI [URI ...]
作用:查看文件内容(可以查看本地和HDFS上的内容)。
示例:
1
2
|
hadoop fs -cat hdfs: //nn1.example.com/file1 hdfs://nn2.example.com/file2 hadoop fs -cat file: ///file3 /user/hadoop/file4 |
(3)-checksum
用法: hadoop fs -checksum URI
作用:查看校验码信息。(例子显示了MD5)
示例:
1
2
|
hadoop fs -checksum hdfs: //nn1.example.com/file1 hadoop fs -checksum file: ///etc/hosts |
(4)-chgrp
用法: hadoop fs -chgrp [-R] GROUP URI [URI ...]
作用:改变文件所属的组。(Change group association of files.)
使用-R 将使改变在目录结构下递归进行。
(5)-chmod
作用:改变文件访问权限。
用法:hadoop fs -chmod [-R] <MODE[,MODE]... | OCTALMODE> URI [URI ...]
这里可以参考 Linux下文件系统的chmod的用法,基本类似。
(6)-chown
作用:hadoop fs -chown [-R] [OWNER][:[GROUP]] URI [URI ]
用法:改变文件的所有者。使用-R 将使改变在目录结构下递归进行。命令的使用者必须是超级用户。
(7)-copyFromLocal
用法:hadoop fs -copyFromLocal <localsrc> URI
作用:类似于put命令,和put不同的是,拷贝的源地址必须是本地文件地址。
-f 参数 当拷贝的目标文件存在时,进行覆盖。
示例:
1
2
|
[root@two1 fanrui]# hadoop fs -copyFromLocal testFlatMap.txt /1.txt copyFromLocal: `/1.txt': File exists |
这个时候加上-f参数。即可覆盖。
1
|
[root@two1 fanrui]# hadoop fs -copyFromLocal -f testFlatMap.txt /1.txt |
(8)-copyToLocal
用法: hadoop fs -copyToLocal [-ignorecrc] [-crc] URI <localdst>
作用:类似于get指令。和get不同的是,拷贝的目的地址必须是本地文件地址。
(9)-count
作用:计算paths下的目录数,文件数和字节数。
用法: hadoop fs -count [-q] [-h] [-v] <paths>
1
2
3
4
|
hadoop fs -count hdfs: //nn1.example.com/file1 hdfs://nn2.example.com/file2 hadoop fs -count -q hdfs: //nn1.example.com/file1 hadoop fs -count -q -h hdfs: //nn1.example.com/file1 hdfs dfs -count -q -h -v hdfs: //nn1.example.com/file1 |
(10)-cp
用法:hadoop fs -cp [-f] [-p | -p[topax]] URI [URI ...] <dest>
作用:拷贝,HDFS文件系统中进行的拷贝操作。
-f 参数选项:当文件存在时,进行覆盖。
-p 参数选项:将权限、所属组、时间戳、ACL以及XAttr等也进行拷贝。下面是官网的描述。
The -p option will preserve file attributes [topx] (timestamps, ownership, permission, ACL, XAttr). If -p is specified with no arg, then preserves timestamps, ownership, permission. If -pa is specified, then preserves permission also because ACL is a super-set of permission. Determination of whether raw namespace extended attributes are preserved is independent of the -p flag.
示例:
1
|
[root@two1 fanrui]# hadoop fs -cp -p /tmp/fan /tmp/fan1 |
(11)-df
用法:hadoop fs -df [-h] URI [URI ...]
作用:显示剩余空间。
示例:
1
2
3
|
[root@two1 fanrui]# hadoop fs -df / Filesystem Size Used Available Use% hdfs: //localhost:9000 37626667008 311296 24792702976 0% |
(12)-dus
作用:显示文件长度概要。该方法已经被舍去,等价于 -du -s 方法。见(11)
(13)-expunge
作用:从垃圾桶目录永久删除超过保留阈值的检查点中的文件,并创建新检查点。
用法:hadoop fs -expunge
(14)-find
作用:查找满足表达式的文件和文件夹。没有配置path的话,默认的就是全部目录/;如果表达式没有配置,则默认为-print。
用法: hadoop fs -find <path> ... <expression> ...
-name pattern 所要查找文件的文件名。
-iname pattern 所要查找的文件名,不区分大小写。
-print 打印。
-print0 打印在一行,如下图所示。
示例:
1
|
hadoop fs -find / -name test -print |
(15)-get
作用:从HDFS上拷贝文件到本地。
用法:hadoop fs -get [-ignorecrc] [-crc] <src> <localdst>
示例:
1
2
|
hadoop fs - get /user/hadoop/file localfile hadoop fs - get hdfs: //nn.example.com/user/hadoop/file localfile |
(16)getfacl
作用:显示文件和文件夹的ACLs(Access Control Lists)。如果目录有默认的ACL,则显示之。
-R参数:递归显示。
用法:
hadoop fs -getfacl [-R] <path>
Options:
- -R: List the ACLs of all files and directories recursively.
- path: File or directory to list.
示例:
1
2
|
hadoop fs -getfacl /file hadoop fs -getfacl -R /dir |
Exit Code:
Returns 0 on success and non-zero on error.
(17)getfattr
作用:显示文件或目录的扩展属性名和值(如果有的话)
用法:hadoop fs -getfattr [-R] -n name | -d [-e en] <path>
Options:
-R:递归显示文件夹和文件。
-n name:转储命名的扩展属性值。
-d:转储与路径名相关联的所有扩展属性值。
-e en: 检索后的值进行编码。 有效的编码是 “text”, “hex”, and “base64”. 值编码作为文本字符串是用双引号括起来的(“),值编码作为16进制和64进制,前缀分别为 0x 和 0s。
path:文件或文件夹路径。
示例:
1
2
|
hadoop fs -getfattr -d /file hadoop fs -getfattr -R -n user.myAttr /dir |
(18)-getmerge
作用:是将HDFS上一个目录中所有的文件合并到一起输出到一个本地文件上。
用法:hadoop fs -getmerge [-nl] <src> <localdst>
示例:
1
2
|
hadoop fs -getmerge -nl /src /opt/output.txt hadoop fs -getmerge -nl /src/file1.txt /src/file2.txt /output.txt |
(19)-help
作用:帮助文档
用法:hadoop fs -help
(20)-ls
作用:查看文件,与linux下ls命令基本类似。
用法:hadoop fs -ls [-d] [-h] [-R] <args>
选项:
-d:只展示查询展示目录;
-h:显示为人眼更易识别的单位(原来是字节)。
-R:递归展示,显示所有的文件夹及文件
示例:
1
2
3
|
hadoop fs -ls -d / hadoop fs -ls -h / hadoop fs -ls -R / |
-lsr
作用:已经被舍去,效果等同于-ls -R
(21)-mkdir
作用:创建文件夹。
用法:hadoop fs -mkdir [-p] <paths>
选项:
-p:创建父目录。类似于Unix的mkdir -p命令。
示例:
1
2
|
hadoop fs -mkdir /user/hadoop/dir1 /user/hadoop/dir2 hadoop fs -mkdir hdfs: //nn1.example.com/user/hadoop/dir hdfs://nn2.example.com/user/hadoop/dir |
(22)-moveFromLocal
用法:hadoop fs -moveFromLocal <localsrc> <dst>
作用:类似于put命令,不同put命令的是,该操作是移动(意思就是localsrc将被删除)。localsrc应是本地文件。
(23)-moveToLocal
用法:hadoop fs -moveToLocal [-crc] <src> <dst>
作用:该命令尚未实现,显示“Not implemented yet”。
(24)-mv
用法:移动文件。
作用: hadoop fs -mv URI [URI ...] <dest>
示例:
1
2
|
hadoop fs -mv /user/hadoop/file1 /user/hadoop/file2 hadoop fs -mv hdfs: //nn.example.com/file1 hdfs://nn.example.com/file2 hdfs://nn.example.com/file3 hdfs://nn.example.com/dir1 |
(25)-put
用法: hadoop fs -put <localsrc> ... <dst>
作用:将本地的文件上传(复制)到HDFS是dst目录下。
示例:
1
2
3
4
|
hadoop fs -put localfile /user/hadoop/hadoopfile hadoop fs -put localfile1 localfile2 /user/hadoop/hadoopdir hadoop fs -put localfile hdfs: //nn.example.com/hadoop/hadoopfile hadoop fs -put - hdfs: //nn.example.com/hadoop/hadoopfile Reads the input from stdin. |
(26)-rm
用法:hadoop fs -rm [-f] [-r |-R] [-skipTrash] URI [URI ...]
作用:删除文件。
选项:
The -f option will not display a diagnostic message or modify the exit status to reflect an error if the file does not exist.
The -R option deletes the directory and any content under it recursively.
The -r option is equivalent to -R.
The -skipTrash option will bypass trash, if enabled, and delete the specified file(s) immediately. This can be useful when it is necessary to delete files from an over-quota directory.
示例:
1
|
hadoop fs -rm hdfs: //nn.example.com/file /user/hadoop/emptydir |
(27)-rmdir
用法:hadoop fs -rmdir [--ignore-fail-on-non-empty] URI [URI ...]
作用:删除空目录。
选项:
—ignore-fail-on-non-empty:使用它的时候,忽略因文件夹非空删除失败的信息。
(28)-rmr
作用:该方法已经被舍去。和-rm -r效果一样。递归删除。
(29)-setfacl
用法:hadoop fs -setfacl [-R] [-b |-k -m |-x <acl_spec> <path>] |[--set <acl_spec> <path>]
作用:设置访问控制列表(ACL)的文件和目录。
选项:
-b:移除所有除了基本的ACL条目。用户、组和其他的条目被保留为与权限位的兼容性。
-k:删除默认的ACL。
-R: 递归应用于所有文件和目录的操作。
-m:修改ACL。新的项目添加到ACL,并保留现有的条目。
-x:删除指定的ACL条目。其他保留ACL条目。
–set:完全替换ACL,丢弃所有现有的条目。acl_spec必须包括用户,组,和其他有权限位的兼容性。
acl_spec:逗号分隔的ACL条目列表。
path:修改文件或目录。
示例:
1
2
3
4
5
6
7
|
hadoop fs -setfacl -m user:hadoop:rw- /file hadoop fs -setfacl -x user:hadoop /file hadoop fs -setfacl -b /file hadoop fs -setfacl -k /dir hadoop fs -setfacl -- set user::rw-,user:hadoop:rw-, group ::r--,other::r-- /file hadoop fs -setfacl -R -m user:hadoop:r-x /dir hadoop fs -setfacl -m default :user:hadoop:r-x /dir |
(30)-setrep
用法:hadoop fs -setrep [-R] [-w] <numReplicas> <path>
作用:改变文件的目标副本系数,放入REP中。选项-R将递归的改变PATH指定的目录中所有文件的目标副本系数。副本系数需要一定的时间才能达到目标值。选项-w将等待副本系数以与目标值相匹配。
示例:
1
|
hadoop fs -setrep -w 3 /user/hadoop/dir1 |
(31)-stat
用法: hadoop fs -stat [format] <path> ...
作用:根据一定格式打印文件/文件夹的统计信息。 文件大小 (%b), 类型 (%F), 所有者所在组 (%g), 名字 (%n), 块大小 (%o), 副本 (%r), 用户名(%u), 修改时间 (%y, %Y)。默认的是%y。
示例:
hadoop fs -stat "%F %u:%g %b %y %n" /file
(32)-tail
用法:hadoop fs -tail [-f] URI
作用:输出文件最后1kb的内容。
选项:
-f:和unix中tail -f命令类似,当文件内容更新时,输出将会改变,具有实时性。
示例:用一个场景测试下。首先HDFS的/目录下有文件mpwtest1.txt
命令:hadoop fs -tail -f /mpwtest1.txt
开启另外一个终端。输入命令: hadoop fs -appendToFile mpwtest2.txt /mpwtest1.txt
可以发现 窗口1 有变化。
(33)-test
作用:判断文件信息
用法:hadoop fs -test -[defsz] URI
选项:
-d:如果路径是一个目录,返回0
-e:如果路径已经存在,返回0
-f: 如果路径是一个文件,返回0
-s:如果路径不是空,返回0
-z:如果文件长度为0,返回0
URI:资源地址,可以是文件也可以是目录。
示例:
1
|
hadoop fs -test -e filename |
(34)-text
用法:hadoop fs -text <src>
作用:将HDFS中文件以文本形式输出(包括zip包,jar包等形式)
示例:hadoop fs -text /wc.jar
(35)-touchz
用法: hadoop fs -touchz URI [URI ...]
作用:创建一个空文件。
示例:hadoop fs -touchz /hello.jar
(35)-truncate
用法: hadoop fs -truncate [-w] <length> <paths>
作用:截断指定长度匹配的所有文件内容。
选项:
- -w:需要等待命令完成块恢复。如果没有-w选项,在恢复的过程中可能是未闭合的。
- length:截断处的值,如果是100,则表示在100B处截断。
- paths:文件地址。
示例:
1
2
|
hadoop fs -truncate 55 /user/hadoop/file1 /user/hadoop/file2 hadoop fs -truncate -w 127 hdfs: //nn1.example.com/user/hadoop/file1 |
(36)-usage
用法: hadoop fs -usage command
作用:返回命令的help信息。
hadoop之 HDFS fs 命令总结的更多相关文章
- Hadoop操作hdfs的命令【转载】
本文系转载,原文地址被黑了,故无法贴出原始链接. Hadoop操作HDFS命令如下所示: hadoop fs 查看Hadoop HDFS支持的所有命令 hadoop fs –ls 列出目录及文件信息 ...
- 【hadoop】 hdfs shell 命令交互
1.put 本地文件上传至hdfs中 2. cat 查看内容 3. 删除文件,文件夹 4. ls 5. copyFromLocal 复制本地文件到HDFS , copyToLocal hdfs 复制到 ...
- Hadoop学习记录(2)|HDFS shell命令|体系结构
HDFS的shell 调用文件系统(FS)shell命令使用hadoop fs的形式 所有的FS shell命令使用URI路径作为参数. URI格式是scheme://authority/path.H ...
- Hadoop:hadoop fs、hadoop dfs与hdfs dfs命令的区别
http://blog.csdn.net/pipisorry/article/details/51340838 'Hadoop DFS'和'Hadoop FS'的区别 While exploring ...
- Hadoop点滴-何时使用hadoop fs、hadoop dfs与hdfs dfs命令
何时使用hadoop fs.hadoop dfs与hdfs dfs命令 编辑 删除 hadoop fs:使用面最广,可以操作任何文件系统. hadoop dfs与hdfs dfs:只能操作HDFS文件 ...
- [转]hadoop hdfs常用命令
FROM : http://www.2cto.com/database/201303/198460.html hadoop hdfs常用命令 hadoop常用命令: hadoop fs 查看H ...
- 在执行hadoop fs命令时,出现WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable错误
错误呈现: 解决过程: (参考链接:https://www.cnblogs.com/kevinq/p/5103653.html) 1.输出hadoop的详细日志,并执行hadoop fs命令来查看错误 ...
- Hadoop基础-HDFS集群中大数据开发常用的命令总结
Hadoop基础-HDFS集群中大数据开发常用的命令总结 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本盘博客仅仅列出了我们在实际生成环境中常用的hdfs命令,如果想要了解更多, ...
- hadoop fs 命令使用
参考:https://segmentfault.com/a/1190000002672666 命令基本格式: hadoop fs -cmd < args > 1.ls hadoop fs ...
随机推荐
- 设计模式--门面模式C++实现
门面模式C++实现 1定义facade 要求一个子系统的外部接口与其内部的通信必须通过一个统一的接口进行.门面模式提供一个高层次的接口,使得子系统更容易视同 注:门面模式注重统一对象,也就是提供一个访 ...
- Linux命令详解-touch
linux的touch命令不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件. 1.命令格式: touch [选项]... 文件... 2.命令参数: -a 或- ...
- Linux命令详解-rm
rm命令.rm是常用的命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录及其下的所有文件及子目录均删除.对于链接文件,只是删除了链接,原有文件均保持不变. rm是一个危险的命 ...
- 1-27 awk 基本使用
大纲: 色彩: awk基本使用 ##################################################### 一.色彩:shell中,设置输出文本色彩(前景色,背景色) ...
- SPOJ-CLEANRBT-状压dp
CLEANRBT - Cleaning Robot #dynamic-programming #bfs Here, we want to solve path planning for a mobil ...
- python2.7安装requests
我这里的是linux CentOS7版本 直接执行命令pip install requests 安装即可,如果提示没有pip这个命令要先安装pip 安装步骤如下: 1. 首先检查Linux有没有安装P ...
- New Concept English three(12)
25W/m 76% Most of us have formed an unrealistic picture of life on a desert island. We sometimes ima ...
- JS中关于把函数作为另一函数的参数的几点小总结
//JS中关于把函数作为函数的参数来传递的问题的小总结//第一,最简单的形式无参函数,直接形式函数的函数名放到括号中,再在执行部分这个函数即可.//当然调用时要穿另一个真正的定义好的函数/*funct ...
- 使用jQuery操作DOM(2)
1.获取设置属性值 attr({属性名1:属性值1,属性名2:属性值2}); //设置属性值 removeAttr(“属性名”); //删除属性 注意:如果元素没有此属性,会不起作用 2.获取同辈元素 ...
- 特征金字塔网络 FPN
一. 提出背景 论文:Feature Pyramid Networks for Object Detection [点击下载] 在传统的图像处理方法中,金字塔是比较常用的一种手段,像 SIFT 基于 ...