hdfs集成springboot使用方法
1.導(dǎo)入maven依賴
<dependency> <groupId>org.apache.hadoop</groupId> <artifactId>hadoop-client-api</artifactId> <version>3.3.6</version> </dependency> <dependency> <groupId>org.apache.hadoop</groupId> <artifactId>hadoop-client-runtime</artifactId> <version>3.3.6</version> </dependency>
2.配置Configuration信息
1)方法1:通過將hdfs的兩個(gè)配置文件(hdfs-site.xml、core-site.xml)放到resources文件夾下后,新建Configuration的時(shí)候設(shè)置為true會(huì)自動(dòng)讀取,也可以通過conf.set(“配置”,“值”)來修改配置項(xiàng)
//創(chuàng)建配置,是否引用core-site.xml和hdfs-site.xml配置文件,true是引用 Configuration conf = new Configuration(true); //創(chuàng)建文件連接流,指定namenode、conf和連接的用戶名 FileSystem fs = FileSystem.get(new URI("mycluster"),conf,"hadoop");
2)方法2:將Configuration設(shè)置為false,不加載默認(rèn)配置文件,直接指定namenode對(duì)應(yīng)的ip和端口如:hdfs://192.168.132.101:8081替換mycluster
Configuration conf = new Configuration(false); FileSystem fs = FileSystem.get(new URI("hdfs://192.168.132.101:8081"),conf,"hadoop");
3.hdfs集成springboot基本命令
1)判斷文件是否存在
fs.exists(new Path("/out.txt"))
2)創(chuàng)建文件夾
fs.mkdirs(new Path("/dir1"));
3)創(chuàng)建文件夾并設(shè)置權(quán)限為文件所有者可讀可寫,文件所有組可讀可寫,其他人可讀
fs.mkdirs(new Path("/dir2"),new FsPermission(FsAction.READ_WRITE,FsAction.READ_WRITE,FsAction.READ));
4)刪除文件夾
fs.delete(new Path("/dir1"),true);
5)創(chuàng)建文件并輸入文本
如果文件存在,默認(rèn)會(huì)覆蓋, 可以通過第二個(gè)參數(shù)進(jìn)行控制。第三個(gè)參數(shù)可以控制使用緩沖區(qū)的大小
FSDataOutputStream out = fs.create(new Path("/test.txt"),true, 4096); out.write("hello hadoop!".getBytes()); out.flush(); out.close();
6)讀取文本
FSDataInputStream inputStream = fs.open(new Path("/test.txt")); byte[] contextBytes = new byte[1024]; inputStream.read(contextBytes); String context = new String(contextBytes,"utf-8"); System.out.println(context);
7)文件重命名
boolean result = fs.rename(new Path("/test.txt"), new Path("/testnew.txt"));
8)上傳文件
fs.copyFromLocalFile(new Path("./data/hello.txt"), new Path("/hdfshello.txt"));
9)下載文件
fs.copyToLocalFile(false, new Path("/hdfshello.txt"), new Path("./data/testdata.txt"), true);
10)輸出所有列表所有文件和文件夾信息
FileStatus[] statuses = fs.listStatus(new Path("/")); for (FileStatus fileStatus : statuses) { System.out.println(fileStatus.toString()); }
11)遞歸查詢目錄所有文件信息,比listStatus多了文本大小,副本系數(shù),塊大小信息
RemoteIterator<LocatedFileStatus> files = fs.listFiles(new Path("/"), true); while (files.hasNext()) { System.out.println(files.next()); }
12)查詢文件塊信息
FileStatus fileStatus = fs.getFileStatus(new Path("/user/master01/data.txt")); BlockLocation[] blocks = fs.getFileBlockLocations(fileStatus, 0, fileStatus.getLen()); for (BlockLocation block : blocks) { System.out.println(block); }
13)查詢文件塊信息并跳轉(zhuǎn)讀取
FileStatus fileStatus = fs.getFileStatus(new Path("/user/master01/data.txt")); BlockLocation[] blocks = fs.getFileBlockLocations(fileStatus, 0, fileStatus.getLen()); FSDataInputStream input = fs.open(new Path("/user/master01/data.txt")); input.seek(blocks[1].getOffset()); //input.seek(0)是讓指針回到開始 System.out.println(input.readLine());
到此這篇關(guān)于hdfs集成springboot使用的文章就介紹到這了,更多相關(guān)hdfs集成springboot內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Cloud Alibaba使用Sentinel實(shí)現(xiàn)接口限流
這篇文章主要介紹了Spring Cloud Alibaba使用Sentinel實(shí)現(xiàn)接口限流,本文詳細(xì)的介紹了Sentinel組件的用法以及接口限流,感興趣的可以了解一下2019-04-04Java通過notify和wait實(shí)現(xiàn)線程間的通信功能
在軟件開發(fā)中,線程是實(shí)現(xiàn)并發(fā)執(zhí)行的重要手段,然而,線程之間的協(xié)作與通信卻是開發(fā)者必須重點(diǎn)考慮的挑戰(zhàn)之一,Java作為一種廣泛應(yīng)用于多線程編程的語(yǔ)言,本文將深入探討Java中通過notify和wait實(shí)現(xiàn)線程間通信的機(jī)制,需要的朋友可以參考下2024-06-06全面解析JPA?倉(cāng)庫(kù)repository中的findAll()方法
這篇文章主要介紹了全面解析JPA?倉(cāng)庫(kù)repository中的findAll()方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02基于SpringBoot和Vue3的博客平臺(tái)發(fā)布、編輯、刪除文章功能實(shí)現(xiàn)
在上一個(gè)教程中,我們已經(jīng)實(shí)現(xiàn)了基于Spring?Boot和Vue3的用戶注冊(cè)與登錄功能。本教程將繼續(xù)引導(dǎo)您實(shí)現(xiàn)博客平臺(tái)的發(fā)布、編輯、刪除文章功能,需要的朋友參考一下2023-04-04如何解決java:找不到符號(hào)符號(hào):類__(使用了lombok的注解)
在使用IntelliJ IDEA開發(fā)Java項(xiàng)目時(shí),可能遇到通過@lombok注解自動(dòng)生成get和set方法不生效的問題,解決這一問題需要幾個(gè)步驟,首先,確認(rèn)Lombok插件已在IDEA中安裝并啟用,其次,確保項(xiàng)目中已添加Lombok的依賴,對(duì)于Maven和Gradle項(xiàng)目2024-10-10Java中反射動(dòng)態(tài)代理接口的詳解及實(shí)例
這篇文章主要介紹了Java中反射動(dòng)態(tài)代理接口的詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-04-04java連接zookeeper實(shí)現(xiàn)zookeeper教程
這篇文章主要介紹了java連接zookeeper實(shí)現(xiàn)zookeeper教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11java利用delayedQueue實(shí)現(xiàn)本地的延遲隊(duì)列
這篇文章主要給大家介紹了java利用delayedQueue實(shí)現(xiàn)本地的延遲隊(duì)列的相關(guān)資料,文中介紹的非常詳細(xì),相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-04-04