HDFS SHELL 详解(6)
data:image/s3,"s3://crabby-images/144e2/144e23067e12e2bb42119d3019bccfc068377254" alt="HDFS SHELL详解(6)"
HDFS SHELL 总共有 39 条指令,本系列将逐步介绍每个指令的功能、选项含义及示例。
系列文章:
25.mv
执行方式:
功能描述:
在 HDFS 内部移动文件
选项解释:
示例:
把/hdfstest/mv_test.txt 移到/hdfstest2
hadoop fs -mv /hdfstest/mv_test.txt /hdfstest2
data:image/s3,"s3://crabby-images/bde97/bde9791e57d058baaf08207668bb72f96334ae04" alt=""
26.put
执行方式
功能描述:
将本地文件上传到 HDFS,与 copyFromLocal 一致
选项解释:
-f:若文件已存在,则覆盖文件
-p:保留源文件的创建时间、修改时间、所属用户及用户组
-l:允许 datanode 延迟保存文件副本到磁盘,让副本数保持为 1
-d:跳过创建._COPYING_的临时文件
示例:
拷贝本地文件 test.txt 到/hdfstest,并覆盖原文件
hadoop fs -put -f test.txt /hdfstest/test.txt
data:image/s3,"s3://crabby-images/a2c44/a2c447cd529f54481ea2adb8a1d7aa5cae2b6a46" alt=""
27.rm
执行方式:
功能描述:
删除文件或删除目录
选项解释:
-f:若文件不存在时,会跳过该文件,不会报错退出
-r|-R:递归指定目录下的所有文件夹/文件
-skipTrash:跳过回收站
-safely:使用该选项时,在删除目录的文件总数大于 hadoop.shell.delete.limit.num.files 之前,将提示安全确认。可以与-skipTrash 一起使用,以防止意外删除大目录
示例:
删除/hdfstest/rm_test.txt
hadoop fs -rm -f /hdfstet/rm_test.txt
data:image/s3,"s3://crabby-images/af0d3/af0d3a914e393a86b9ae6b27845470a95d917eaa" alt=""
递归删除/hdfstest2 目录
hadoop fs -rm -R -skipTrash -safely /hdfstest2
data:image/s3,"s3://crabby-images/607ef/607efb563d64b0595538dffc3211d2864208f0fb" alt=""
28.rmdir
执行方式:
功能描述:
删除空目录
选项解释:
--ignore-fail-on-non-empty:若目录不为空,则不会报错
示例:
删除/hdfstest2
hadoop fs -rmdir /hdfstest2
data:image/s3,"s3://crabby-images/872bb/872bb15bd6ae96388452d86432a21d321aa2cce4" alt=""
hadoop fs -rmdir --ignore-fail-on-non-empty /hdfstest2
data:image/s3,"s3://crabby-images/9306d/9306d43058f363fb1f5dc3ec3f4931b15e69d1fe" alt=""
删除/hdfstest2/rm_dir
hadoop fs -rmdir /hdfstest2/rm_dir
data:image/s3,"s3://crabby-images/8cca6/8cca675af9f7176657a1380844eb55d62b23fbf1" alt=""
29.setfacl
执行方式:
功能描述:
设置对象或目录的 ACL(访问控制列表)
选项解释:
-b:剔除 user、group 及 other 外的 ACL
-k:剔除 default ACL
-m:添加新的 ACL 条目
-x:删除指定的 ACL 条目
--set:添加新的 ACL 条目并覆盖原有的 ACL 条目
-R:递归指定路径下的所有文件及文件夹
acl_spec:
ACL 条目,填写规范为<user/group/other>:<用户名/组别名>:<r/w/x/-(必须达到 3 位权限)>,比如 user:luorl:rw-,为 luorl 用户添加读写权限;group::rwx,为基本组别用户权限调整为读写执行。
示例:
为/hdfstest/test.txt 添加 luorl 用户读写权限
hadoop fs -setfacl -m user:luorl:rw- /hdfstest/test.txt
data:image/s3,"s3://crabby-images/29c06/29c06156333505688c74b12cf3c32146b06781fc" alt=""
剔除上述添加的 luorl 用户权限
hadoop fs -setfacl -b /hdfstest/test.txt
data:image/s3,"s3://crabby-images/66345/66345cc73dc59f0a98f672e0fd2140a7ae2b7bca" alt=""
为/hdfstest/添加 luorl 用户读写权限,并设置为 defalut ACL
hadoop fs -setfacl -m default:user:luorl:rw- /hdfstest
data:image/s3,"s3://crabby-images/f46b7/f46b7102c142d40f97ea380c9613dee63383151c" alt=""
设置目录的 defalut ACL 后,后续在该目录下新建的文件夹/文件都会带上 default ACL
data:image/s3,"s3://crabby-images/d04bc/d04bcb5c63a30e7e72244afa40374f9ba5233766" alt=""
剔除上述添加的 luorl 用户的 defalut ACL
hadoop fs -setfacl -k /hdfstest
data:image/s3,"s3://crabby-images/75036/7503629a8c3388bb49222bec6c2d9284f003ba60" alt=""
为/hdfstest/test.txt 设置 user::rwx,user:luorl:rw,group::rw-,other::r—权限,并覆盖原有权限
重新设置/hdfstest/test.txt 文件的权限
data:image/s3,"s3://crabby-images/100a1/100a138fbb7570c767ea7ee3b4b6e4ca2e518b56" alt=""
hadoop fs -setfacl --set user::rwx,user:luorl:rw-,group::rw-,other::r-- /hdfstest/test.txt
data:image/s3,"s3://crabby-images/77193/7719355f87f1eede66ee8a5853e7ef7973d8832d" alt=""
可见文件权限已被完全覆盖
版权声明: 本文为 InfoQ 作者【罗小龙】的原创文章。
原文链接:【http://xie.infoq.cn/article/04270934272b2edea58ef0191】。文章转载请联系作者。
评论