HDFS的Shell操作(开发重点)

基本语法

方式1: hadoop fs 具体命令

方式2: hdfs dfs 具体命令

常用命令

一共分三大类命令:上传、下载、HDFS直接操作

准备工作

1.启动Hadoop集群

[ranan@hadoop102 hadoop-3.1.3]$ myhadoop.sh start
# 或者也可以像之前一样分别在102,103上使用以下两个命令:
[ranan@hadoop102 hadoop-3.1.3]$ sbin/start-dfs.sh
[ranana@hadoop103 hadoop-3.1.3]$ sbin/start-yarn.sh

2.查看命令帮助,如果对某个命令的用法不清楚

[ranan@hadoop102 ~]$ hadoop fs -help rm

3.创建/sanguo文件

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -mkdir /sanguo

后续的命令在该文件夹下操作

上传

-moveFromLocal 剪切

从本地剪切粘贴到HDFS

基本语法:hadoop fs -moveFromLocal 原文件 上传路径

[ranan@hadoop102 hadoop-3.1.3]$ vim shuguo.txt
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -moveFromLocal ./shuguo.txt /sanguo

-copyFromLocal 拷贝

从本地文件系统中拷贝文件到HDFS路径

基本语法:hadoop fs -copyFromLocal 原文件 上传路径

[ranan@hadoop102 hadoop-3.1.3]$ vim weiguo.txt
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -copyFromLocal weiguo.txt /sanguo

-put 拷贝 (常用)

等同于copyFromLocal,生产环境更习惯用put

基本语法:hadoop fs -put 原文件 上传路径

[ranan@hadoop102 hadoop-3.1.3]$ vim wuguo.txt
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -put wuguo.txt /sanguo

-appendToFile 追加

追加一个文件到已经存在的文件末尾

文件只能追加,不能修改

基本语法:hadoop fs -appendToFile 追加的文件 被追加的文件

[ranan@hadoop102 hadoop-3.1.3]$ vim liubei.txt
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -appendToFile liubei.txt /sanguo/shuguo.txt

下载

-copyToLocal 下载

从HDFS拷贝到本地

基本语法:hadoop fs -copyToLocal HDFS的路径 拷贝到本地的路径

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -copyToLocal /sanguo/shuguo.txt ./

-get 下载

等同于copyToLocal,生产环境更习惯用get

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -get /sanguo/shuguo.txt ./shuguo2.txt

下载的时候可以改文件名

HDFS直接操作

基本使用于linux相同

-ls 显示目录信息

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -ls /sanguo

-cat 显示文件内容

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -cat /sanguo/shuguo.txt

-chgrp/-chmod/-chown/ 修改文件所属权限

和Linux文件系统中的用法一样

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -chgrp ranan /sanguo/shuguo.txt

-mkdir 创建路径

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -mkdir /jinguo

-cp HDFS中拷贝

将shuguo.txt拷贝到/jinguo

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -cp /sanguo/shuguo.txt /jinguo



-mv 在HDFS目录中移动文件

mv oldNameFile newNameFile(重命名)

mv 原目录 目标目录(移动剪切)

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -mv /sanguo/wuguo.txt /jinguo
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -mv /sanguo/weiguo.txt /jinguo

-tail 显示文件末尾的数据

显示文件末尾1kb的数据。因为只能追加修改,末尾的一般是最新的。

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -tail /jinguo/shuguo.txt

-rm 删除文件/文件夹

删除指令要注意使用

-rm 删除文件或文件夹

-rm -r 递归删除文件夹及文件夹里面的类容

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -rm /sanguo/shuguo.txt
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -rm -r /sanguo

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

-s 显示总共的

-h 显示具体的细节

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -du -s /jinguo
[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -du -h /jinguo

-setrep 设置HDFS中文件的副本数量

[ranan@hadoop102 hadoop-3.1.3]$ hadoop fs -setrep 10 /jinguo/shuguo.txt

但是我们只有三台服务器,实际还是只有3个副本。因为每台机器只能存储其一份副本

副本数会记录在 NameNode 的元数据中,如果后续增加服务器,会拷贝副本过去。

HDFS02 HDFS的Shell操作的更多相关文章

  1. Hadoop开发第6期---HDFS的shell操作

    一.HDFS的shell命令简介 我们都知道HDFS 是存取数据的分布式文件系统,那么对HDFS 的操作,就是文件系统的基本操作,比如文件的创建.修改.删除.修改权限等,文件夹的创建.删除.重命名等. ...

  2. 大数据:Hadoop(JDK安装、HDFS伪分布式环境搭建、HDFS 的shell操作)

    所有的内容都来源与 Hadoop 官方文档 一.Hadoop 伪分布式安装步骤 1)JDK安装 解压:tar -zxvf jdk-7u79-linux-x64.tar.gz -C ~/app 添加到系 ...

  3. Hadoop读书笔记(二)HDFS的shell操作

    Hadoop读书笔记(一)Hadoop介绍:http://blog.csdn.net/caicongyang/article/details/39898629 1.shell操作 1.1全部的HDFS ...

  4. HDFS基本shell操作

    在客户端输入Hadoop fs,可以查看所有的,hadoop shell # -help [cmd] //显示命令的帮助信息,如: hadoop fs -help ls # -ls(r) <pa ...

  5. HDFS的shell操作

    bin/hadoop命令操作: namenode -format 格式化文件系统 fs(缩写:FileSystem) 运行一个文件系统的用户客户端 bin/hadoop fs常用命令操作: -ls h ...

  6. [HDFS_2] HDFS 的 Shell 操作

    0. 说明 在 Shell 下完成对 HDFS 的增删改查操作 1. 在 Shell 下完成对 HDFS 的增删改查操作 [1.0 查看帮助] [centos@s101 ~]$ hdfs dfs -h ...

  7. Hadoop框架之HDFS的shell操作

    既然HDFS是存取数据的分布式文件系统,那么对HDFS的操作,就是文件系统的基本操作,比如文件的创建.修改.删除.修改权限等,文件夹的创建.删除.重命名等.对HDFS的操作命令类似于Linux的she ...

  8. Hadoop HDFS的Shell操作实例

    本文发表于本人博客. 我们知道HDFS是Hadoop的分布式文件系统,那既然是文件系统那最起码会有管理文件.文件夹之类的功能吧,这个类似我们的Windows操作系统一样的吧,创建.修改.删除.移动.复 ...

  9. 4 weekend110的hdfs&mapreduce测试 + hdfs的实现机制初始 + hdfs的shell操作 + 无密登陆配置

    Hdfs是根/目录,windows是每一个盘符, 1  从Linux里传一个到,hdfs里去 2  从hdfs里下一个到,linux里去 想从hdfs里,下载到linux, 涨知识,记住,hdfs是建 ...

随机推荐

  1. .NET Core TLS 协议指定被我钻了空子~~~

    前言 此前,测试小伙伴通过工具扫描,平台TLS SSL协议支持TLS v1.1,这不安全,TLS SSL协议至少是v1.2以上才行,想到我们早已将其协议仅支持v1.3,那应该非我们平台问题.我依然自信 ...

  2. Docker 安装 MySQL8

    1. 环境准备 创建挂载数据目录和配置文件 mkdir -p /mnt/mysql/data /etc/mysql/conf touch /etc/mysql/conf/my.cnf 2. 拉取镜像 ...

  3. 谷歌chrome多个相同用户登陆同一个机器多开配置

    创建快捷方式,目标中填写:路径+参数如下所示即可 参数:--user-data-dir=%LOCALAPPDATA%\Google\Chrome\%SessionName%

  4. topk算法

    方法一 堆排序 自建堆 heapMax方法,从上至下调整堆 pop时,可以使用自上而下调整堆,调用heapMax(arr,0,sz-1); push时,需要自下到上调整即 从上到下调整: void h ...

  5. leakcanary内存泄漏:此篇有加了内存泄漏的apk demo

    概括:   ·用Android studio写一个demo     ·配置leakcanary     ·加入内存泄漏代码片段     ·安装apk 验证结果     ·源码地址 一.android ...

  6. [第二章]c++学习笔记3(构造函数)

    成员函数的一种 (1)名字与类名相同,可以有参数,不能有返回值(void也不行) (2)作用是对对象初始化,如给成员变量赋初值 (3)如果定义类时没写构造函数,则编译器生成一个默认的无参数的构造函数( ...

  7. Spring Cloud Gateway实战之三:动态路由

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  8. 【Microsoft Azure 的1024种玩法】四. 利用Azure Virtual machines 打造个人专属云盘,速度吊打某云盘

    [简介] 1.Azure Virtual machines是Azure 提供的多种可缩放按需分配计算资源之一,Nextcloud是一款开源免费的私有云存储网盘项目,可以让你快速便捷地搭建一套属于自己或 ...

  9. vue3 学习笔记 (五)——vue3 的 setup 如何实现响应式功能?

    setup 是用来写组合式 api ,内部的数据和方法需要通过 return 之后,模板才能使用.在之前 vue2 中,data 返回的数据,可以直接进行双向绑定使用,如果我们把 setup 中数据类 ...

  10. [atARC061F]Card Game for Three

    记录每一次操作的玩家为操作序列(去掉第一次),需要满足:$a$的个数为$n$且以$a$为结尾,$b$和$c$的个数分别不超过$m$和$k$ 其所对应的概率:每一个字符恰好确定一张卡牌,因此即$3^{n ...