Java怎么實現HDFS文件上傳下載_第1頁
Java怎么實現HDFS文件上傳下載_第2頁
Java怎么實現HDFS文件上傳下載_第3頁
Java怎么實現HDFS文件上傳下載_第4頁
Java怎么實現HDFS文件上傳下載_第5頁
已閱讀5頁,還剩1頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第Java怎么實現HDFS文件上傳下載project.build.sourceEncodingUTF-8/project.build.sourceEncoding

piler.source1.8/piler.source

piler.target1.8/piler.target

hadoop.version3.1.3/hadoop.version

/properties

!--依賴庫--

dependencies

dependency

groupIdorg.apache.hadoop/groupId

artifactIdhadoop-common/artifactId

version${hadoop.version}/version

/dependency

dependency

groupIdorg.apache.hadoop/groupId

artifactIdhadoop-mapreduce-client-core/artifactId

version${hadoop.version}/version

/dependency

/dependencies

2、創建與刪除

importorg.apache.hadoop.conf.Configuration;

importorg.apache.hadoop.fs.FileSystem;

importorg.apache.hadoop.fs.Path;

importjava.io.IOException;

publicstaticvoidmAIn(String[]args){

//初始化hadoop文件系統的configration對象

Configurationconf=newConfiguration();

//將hadoop的configration信息傳入

conf.set(fs.defaultFS,hdfs://02:9000

//初始化Hadoop文件系統的句柄

FileSystemfs=null;

try{

//配置Hadoop的文件句柄信息

fs=FileSystem.get(conf);

//定義Hadoop的文件路徑

finalStringPATH=/test/kb16/hadoop/ratings.csv

//初始化Hadoop的路徑信息

Pathpath=newPath(PATH);

//如果文件路徑存在就刪除

if(fs.exists(path)){

System.out.println(DELETE+fs.delete(path,true));

}else{

//如果文件路徑不存在就創建

System.out.println(CREATE+fs.create(path));

}catch(IOExceptione){

e.printStackTrace();

}finally{

//結束的時候,句柄還沒有釋放就進行釋放

if(fs!=null){

try{

fs.close();

}catch(IOExceptione){

e.printStackTrace();

}

3、文件上傳

importorg.apache.hadoop.conf.Configuration;

importorg.apache.hadoop.fs.FileSystem;

importorg.apache.hadoop.fs.Path;

importjava.io.File;

importjava.io.IOException;

publicstaticvoidmain(String[]args){

//定義本地上傳文件路徑

finalStringformPath=E:\\ratings.csv

//本地文件不存在就報錯,并強制讓程序終止

if(!newFile(formPath).exists()){

System.out.println(formPath+doesntexits

return;

//初始化hadoop文件系統的configration對象

Configurationconf=newConfiguration();

//將hadoop的configration信息傳入

conf.set(fs.defaultFS,hdfs://02:9000

//初始化Hadoop文件系統的句柄

FileSystemfs=null;

try{

//將config信息傳入

fs=FileSystem.get(conf);

//定義上傳到HDFS的路徑

finalStringtoPath=/test/kb16/hive

//初始化路徑

Pathto=newPath(toPath);

//如果文件路徑存在不執行,如果文件路徑不存在就嘗試創建,如果創建失敗就跳過

if(!fs.exists(to)!fs.mkdirs(to)){

System.out.println(toPath+doesntexitandcantbecreated

return;

//初始化上傳文件路徑

Pathfrom=newPath(formPath);

//利用方法將本地文件復制到HDFS中

fs.copyFromLocalFile(from,to);

System.out.println(succeedincopyingfrom+formPath+to+toPath);

}catch(IOExceptione){

e.printStackTrace();

System.out.println(FAILURE

}finally{

//如果結束Hadoop文件系統句柄沒有關閉,利用方法進行句柄釋放

if(null!=fs){

try{

fs.close();

}catch(IOExceptione){

e.printStackTrace();

}

4、文件下載

importernal.cglib.core.$LocalVariablesSorter;

importxy.$Factory;

importorg.apache.hadoop.conf.Configuration;

importorg.apache.hadoop.fs.FileSystem;

importorg.apache.hadoop.fs.Path;

importjava.io.File;

importjava.io.IOException;

publicclassDownload{

publicstaticvoidmain(String[]args){

//定義文件下載路徑

finalStringtoPath=C:\\Users\\Jialin\\Desktop

//獲取路徑

Fileto=newFile(toPath);

//如果路存在或者文件路徑不存在但是創建成功就不執行if方法

if(!to.exists()!to.mkdirs()){

System.err.println(toPath+doesntexistandcantbecreated

return;

//初始化hadoop文件系統的configration對象

Configurationconfig=newConfiguration();

//將hadoop的configration信息傳入

config.set(fs.defaultFS,hdfs://02:9000

//初始化Hadoop文件系統的句柄

FileSystemfs=null;

try{

//將config信息傳入

fs=FileSystem.get(config);

//定義下載文件路徑

finalStringfromPath=/test/kb16/hive/ratings.csv

//獲取路徑信息

Pathfrom=newPath(fromPath);

//如果指定下載文件不存在就退出

if(!fs.exists(from)){

System.err.println(toPath+doesntexist

return;

//獲取文件下載路徑信息

Path_to=newPath(toPath);

//利用方法將Hadoop文件下載到本地

fs.copyToLocalFile(from,_to);

System.out.println(succeedindownloadingfrom+fromPath+to+toPath);

}catch(IOExcepti

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論