Hadoop之HDFS常用Shell命令

本文详细介绍了Hadoop HDFS的常用Shell命令,包括启动集群、文件操作如上传、下载、查看、权限设置、复制、移动、删除等,以及目录管理与权限调整,为Hadoop开发者提供快速查阅与实践指南。

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

Hadoop之HDFS常用Shell命令


  1. 启动Hadoop集群
 sbin/start-dfs.sh
 sbin/start-yarn.sh
  1. -help:输出这个命令参数
hadoop fs -help rm
  1. -ls: 显示目录信息
hadoop fs -ls /
  1. -mkdir:在hdfs上创建目录
hadoop fs -mkdir -p /hadoop
  1. -moveFromLocal从本地剪切粘贴到hdfs
hadoop fs  -moveFromLocal  ./hh.txt  /hadoop
  1. -cat:显示文件内容
hadoop fs -cat /hadoop/hh.txt
  1. -tail:显示一个文件的末尾
adoop fs -tail /hadoop/hh.txt
  1. -chgrp 、-chmod、-chown:linux文件系统中的用法一样,修改文件所属权限
hadoop fs  -chmod  666  /hadoop/hh.txt
hadoop fs  -chown  centos:centos  /hadoop/hh.txt
  1. -copyFromLocal:从本地文件系统中拷贝文件到hdfs路径去
hadoop fs -copyFromLocal README.txt /
  1. -copyToLocal:从hdfs拷贝到本地
hadoop fs -copyToLocal /hadoop/hh.txt ./
  1. -cp :从hdfs的一个路径拷贝到hdfs的另一个路径
hadoop fs -cp /hadoop/hh.txt /admin/hah.txt
  1. -mv:在hdfs目录中移动文件
hadoop fs -mv /hh.txt /admin
  1. -get:等同于copyToLocal,就是从hdfs下载文件到本地
hadoop fs -get /hadoop/hh.txt ./
  1. -getmerge :合并下载多个文件,比如hdfs的目录 /aaa/下有多个文件:log.1, log.2,log.3,…
hadoop fs -getmerge /user/test/* ./hh.txt
  1. -put:等同于copyFromLocal
hadoop fs -put ./zaiyiqi.txt /user/test/
  1. -rm:删除文件或文件夹
hadoop fs -rm /user/test/jinlian2.txt
  1. -rmdir:删除空目录
hadoop fs -rmdir /test
  1. -du统计文件夹的大小信息
hadoop fs -du -s -h /user/test
  1. -setrep:设置hdfs中文件的副本数量
 hadoop fs -setrep 10 /hadoop/hh.txt

这里设置的副本数只是记录在NameNode的元数据中,是否真的会有这么多副本,还得看DataNode的数量。因为目前只有3台设备,最多也就3个副本,只有节点数的增加到10台时,副本数才能达到10。


hadoop fs、hadoop dfs与hdfs dfs命令的区别

Hadoop fs:使用面最广,可以操作任何文件系统。
hadoop dfs与hdfs dfs:只能操作HDFS文件系统相关(包括与Local FS间的操作),前者已经Deprecated,一般使用后者。

### 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、付费专栏及课程。

余额充值