Java Api操作HDFS

本文详细介绍了使用Java进行HDFS操作,包括文件上传、覆盖/追加、下载、权限查看、目录遍历、文件创建/删除、内容追加、文件移动以及配置问题的解决。作者通过示例代码展示了如何处理各种场景,并分享了配置core-site.xml的注意事项。
摘要由CSDN通过智能技术生成

示例代码

链接:https://pan.baidu.com/s/1yUnJh-j9EKmL2hPF8biAtg?pwd=dv12 提取码:dv12

鼠鼠遇到的坑!!!

  • 之前配置的Hadoopcore-site.xml文件中的配置的fs.defaultFS地址是hdfs://localhost:9000,然后后面Java连不上hdfs
  • 9000端口也是打开了,但就是连不上
  • 9870端口也能正常访问
  • 在这里插入图片描述
  • 防火墙也关闭了,也不行
  • 查阅诸多资料发现问题是Hadoop配置文件core-site.xmlfs.defaultFS地址问题
  • 只需将localhost改为自身IP即可
  • core-site.xml配置如下
<configuration>
    <property>
        <name>hadoop.tmp.dir</name>
        <value>file:/opt/hadoop/tmp</value>
        <description>location to store temporary files</description>
    </property>
    <property>
        <name>fs.defaultFS</name>
        <value>hdfs://shushu:9000</value>
        <!-- <value>hdfs://localhost:9000</value> -->
    </property>
</configuration>
  • 修改完后重启Hadoop
  • Java即可成功连接

HDFS常量类用于配置HDFS

  • 在这里插入图片描述

HDFS配置相关代码

  • 在这里插入图片描述

1.向 HDFS 中上传任意文本文件,如果指定的文件在 HDFS 中已经存在,由用户指定是追加到原有文件末尾还是覆盖原有的文件。

代码实现

  • 在这里插入图片描述
  • 在这里插入图片描述

测试

文件不存在
  • 查看当前HDFS文件是否存在
    -在这里插入图片描述

  • 本地文件内容

  • 在这里插入图片描述

  • 测试代码,方法首先会判断文件是否存在,此时无论选择哪个参数,都是直接上传

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看是否成功,如图成功

覆盖
  • 查看当前HDFS文件为内容hello

  • 在这里插入图片描述

  • 本地文件内容为hello world!

  • 在这里插入图片描述

  • 测试代码(选择OVER_WRITE参数)

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS文件内容是否为hello world!,如图覆盖成功

追加到末尾
  • 查看当前HDFS文件为内容hello world!

  • 本地文件内容为Haoop!

  • 在这里插入图片描述

  • 测试代码(选择APPEND_TO_END参数)

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS文件内容是否为hello world!Hadoop!,如图追加成功

2.从 HDFS 中下载指定文件,如果本地文件与要下载的文件名称相同,则自动对下载的文件重命名。

代码实现

  • 在这里插入图片描述

测试

本地不存在同名文件
  • 查看HDFS文件内容hello world!Hadoop!

  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看下载下来的文件内容是否为hello world!Hadoop!,如图成功

  • 在这里插入图片描述

本地存在同名文件
  • 查看HDFS文件内容hello Java!

  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看下载下来并重命名的文件内容是否为hello Java!,如图成功

  • 在这里插入图片描述

将 HDFS 中指定文件的内容在终端显示。

代码实现

测试

  • 查看HDFS文件内容hello Java!

  • 测试代码

  • 运行结果(结果与HDFS文件内容hello Java!一致,成功)

  • 在这里插入图片描述

显示HDFS中指定的文件读写权限、大小、创建时间、路径等信息。

代码实现

  • 在这里插入图片描述

测试

  • shell命令查看HDFS文件信息

  • 测试代码

  • 运行结果(与shell命令执行结果一致,成功)

  • 在这里插入图片描述

3.给定HDFS中某一个目录,输出该目录下的所有文件的读写权限、大小、创建时间、路径等信息。

代码实现

  • 在这里插入图片描述

测试

  • shell命令查看HDFS目录信息

  • 在这里插入图片描述

  • 测试代码

  • 运行结果(与shell命令执行结果一致,成功)

  • 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

4.提供一个 HDFS 中的文件的路径,对该文件进行创建和删除操作。如果文件所在目录不存在,则自动创建目录。

代码实现

  • 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

测试

文件所在目录存在
  • 测试代码

  • 运行结果

  • 在这里插入图片描述

文件所在目录不存在
  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

5.向HDFS中指定的文件追加内容,由用户指定将内容追加到原有文件的开头或结尾。

代码实现

  • 在这里插入图片描述

  • 在这里插入图片描述

测试

追加到开头
  • HDFS文件内容为Hadoop

  • 本地文件内容为Hello!

  • 在这里插入图片描述

  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS文件内容是否为Hello!Hadoop,如图成功

追加到结尾
  • HDFS文件内容为Hello!Hadoop

  • 本地文件内容为!Java

  • 在这里插入图片描述

  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS文件内容是否为Hello!Hadoop!Java,如图成功

6.删除 HDFS 中指定的文件。

代码实现

  • 在这里插入图片描述

测试

  • 查看要删除的HDFS文件

  • 在这里插入图片描述

  • 测试代码

  • 在这里插入图片描述

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS是否删除,如图成功

  • 在这里插入图片描述

7.在HDFS中将文件从源路径移动到目的路径。

代码实现

  • 在这里插入图片描述

测试

/user/root/test.txt文件移动到/user/root/test目录下
  • 查看HDFS/user/root/test目录下没有文件

  • 在这里插入图片描述

  • 测试代码

  • 运行结果

  • 在这里插入图片描述

  • 查看HDFS,如图移动成功

  • 在这里插入图片描述

  • 22
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值