編寫Java代碼對HDFS進行增刪改查操作代碼實例
更新時間:2019年04月10日 11:10:09 作者:Alvis zhao
這篇文章主要介紹了Java代碼對HDFS進行增刪改查操作,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
本文實例為大家分享了Java代碼對HDFS進行增刪改查操作的具體代碼,供大家參考,具體內容如下
import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.net.URI; import org.apache.commons.compress.utils.IOUtils; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.BlockLocation; import org.apache.hadoop.fs.FSDataInputStream; import org.apache.hadoop.fs.FSDataOutputStream; import org.apache.hadoop.fs.FileStatus; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; public class FileOpreation { public static void main(String[] args) throws IOException { //CreateFile(); //DeleteFile(); //CopyFileToHDFS(); //MkDirs(); //DelDirs(); ListDirectory(); DownLoad(); } public static void CreateFile() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration =new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); byte[] file_content_buff="hello hadoop world, test write file !\n".getBytes(); Path dfs = new Path("/home/test.txt"); FSDataOutputStream outputStream = fSystem.create(dfs); outputStream.write(file_content_buff.length); } public FileOpreation() { // TODO Auto-generated constructor stub }public static void DeleteFile() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration =new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); Path deletf = new Path("/home/test.txt"); boolean delResult = fSystem.delete(deletf,true); System.out.println(delResult==true?"刪除成功":"刪除失敗"); } public static void CopyFileToHDFS() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration =new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); Path src = new Path("E:\\SerializationTest\\APITest.txt"); Path dest_src = new Path("/home"); fSystem.copyFromLocalFile(src, dest_src); } public static void MkDirs() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration =new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); Path src = new Path("/Test"); fSystem.mkdirs(src); } public static void DelDirs() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration = new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); Path src = new Path("/Test"); fSystem.delete(src); } public static void ListDirectory() throws IOException { String uri = "hdfs://Alvis:9000"; Configuration configuration = new Configuration(); FileSystem fSystem = FileSystem.get(URI.create(uri), configuration); FileStatus[] fStatus = fSystem.listStatus(new Path("/output")); for(FileStatus status : fStatus) if (status.isFile()) { System.out.println("文件路徑:"+status.getPath().toString()); System.out.println("文件路徑 getReplication:"+status.getReplication()); System.out.println("文件路徑 getBlockSize:"+status.getBlockSize()); BlockLocation[] blockLocations = fSystem.getFileBlockLocations(status, 0, status.getBlockSize()); for(BlockLocation location : blockLocations){ System.out.println("主機名:"+location.getHosts()[0]); System.out.println("主機名:"+location.getNames()[0]); } } else { System.out.println("directory:"+status.getPath().toString()); } } public static void DownLoad() throws IOException { Configuration configuration = new Configuration(); configuration.set("fs.defaultFS", "hdfs://Alvis:9000"); FileSystem fSystem =FileSystem.get(configuration); FSDataInputStream inputStream =fSystem.open( new Path("/input/wc.jar")); FileOutputStream outputStream = new FileOutputStream(new File("E:\\LearnLife\\DownLoad\\wc.jar")); IOUtils.copy(inputStream, outputStream); System.out.println("下載成功!"); } }
思想:
一、定義虛擬機接口
二、先拿到HDFS遠程調用接口對象Configuration
三、定義分布式文件系統(tǒng)FileSystem對象獲取對象
四、給定路徑
五、用FileSystem對象調用操作
以上所述是小編給大家介紹的Java代碼對HDFS進行增刪改查操作詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
springboot?實現(xiàn)不同context-path下的會話共享
這篇文章主要介紹了springboot?實現(xiàn)不同context-path下的會話共享,基于很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01使用restTemplate.postForEntity()的問題
這篇文章主要介紹了使用restTemplate.postForEntity()的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09Spring RedisTemplate 批量獲取值的2種方式小結
這篇文章主要介紹了Spring RedisTemplate 批量獲取值的2種方式小結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06