大数据之Hadoop学习(一)利用Shell命令与HDFS进行交互


在学习HDFS编程实践前,我们需要启动Hadoop。执行如下命令:

一、启动Hadoop

cd /usr/local/hadoop
./sbin/start-dfs.sh #启动hadoop

在这里插入图片描述

二、利用Shell命令与HDFS进行交互

终端输入如下命令,查看fs总共支持了哪些命令

./bin/hadoop fs

在这里插入图片描述
在终端输入如下命令,可以查看具体某个命令的作用
例如:我们查看put命令如何使用,可以输入如下命令:

./bin/hadoop fs -help put

在这里插入图片描述

1.目录操作

cd /usr/local/hadoop
./bin/hdfs dfs -mkdir -p /user/hadoop

该命令中表示在HDFS中创建一个“/user/hadoop”目录,“–mkdir”是创建目录的操作,“-p”表示如果是多级目录,则父目录和子目录一起创建,这里“/user/hadoop”就是一个多级目录,因此必须使用参数“-p”,否则会出错。
在这里插入图片描述
列出HDFS上的所有目录,可以使用如下命令:

 ./bin/hdfs dfs -ls /

在这里插入图片描述
在/user/hadoop/中创建一个二级目录input

./bin/hdfs dfs -mkdir /user/hadoop/input

在这里插入图片描述
HDFS的根目录下创建一个名称为input的目录,则需要使用如下命令:

./bin/hdfs dfs -mkdir /input

在这里插入图片描述
使用rm命令删除刚刚创建的根目录下的input目录
(可以使用rm命令删除一个目录,比如,可以使用如下命令删除刚才在HDFS中创建的“/input”目录(不是“/user/hadoop/input”目录):)

./bin/hdfs dfs –rm –r /input

在这里插入图片描述
上面命令中,“-r”参数表示如果删除“/input”目录及其子目录下的所有内容,如果要删除的一个目录包含了子目录,则必须使用“-r”参数,否则会执行失败。

2.文件操作

创建一个文件my.txt

touch my.txt

在这里插入图片描述

在这里插入图片描述
在my.txt文件中输入
Hadoop
Spark
XMU DBLAB
在这里插入图片描述
使用如下命令把本地文件系统的“/usr/local/hadoop/my.txt”上传到HDFS中的当前用户目录的input目录下,也就是上传到HDFS的“/user/hadoop/input/”目录下:

./bin/hdfs dfs -put ./my.txt  /user/hadoop/input

在这里插入图片描述

使用ls命令查看一下文件是否成功上传到HDFS中,具体如下:

/bin/hdfs dfs -ls /user/hadoop/input

在这里插入图片描述
使用如下命令查看HDFS中的my.txt这个文件的内容:

./bin/hdfs dfs  -cat /user/hadoop/input/my.txt

在这里插入图片描述
下面把HDFS中的my.txt文件下载到本地文件系统中的“/home/weiwei/下载/”这个目录下

./bin/hdfs dfs -get /user/hadoop/input/my.txt /home/weiwei/下载

在这里插入图片描述

使用如下命令,到本地文件系统查看下载下来的文件my.txt:

 cd ~
 cd 下载
 ls
 cat my.txt

在这里插入图片描述
把HDFS的“/user/hadoop/input/my.txt”文件,拷贝到HDFS的另外一个目录“/input”中(因为之前的根目录下的input目录删除了,现在重新创建input目录)

./bin/hdfs dfs -cp /user/hadoop/input/my.txt  /input

在这里插入图片描述
查看是否拷贝成功:

./bin/hdfs dfs -ls /input

在这里插入图片描述
说明已经拷贝进去。

  • 7
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值