zoukankan      html  css  js  c++  java
  • apihadoophadoop通过FileSystem API读取和写入数据

    本文纯属个人见解,是对前面学习的总结,如有描述不正确的地方还请高手指正~

        看hadoop指南(有更好的源码),自己测试着写了一个小例子,在伪分布式上测试胜利,对JAVA的一些API也不太了解,都是一个熟悉的过程吧。

        

        这个例子重要可以熟悉一些API,以及懂得各个类之间的调用和转化关系,重新学习一门语言,重要还是API的一些操纵问题,慢慢来吧,别着急,come on.

        

        每日一道理
    整个世界,因为有了阳光,城市有了生机;细小心灵,因为有了阳光,内心有了舒畅。明媚的金黄色,树丛间小影成像在叶片上泛有的点点破碎似的金灿,海面上直射反映留有的随波浪层层翻滚的碎片,为这大自然创造了美景,惹人醉的温馨之感,浓浓暖意中夹杂着的明朗与柔情,让雨过天晴后久违阳光的心灵重新得到了滋润!
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.net.URI;
    
    
    import org.apache.hadoop.io.IOUtils;
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.fs.FileSystem;
    import org.apache.hadoop.fs.Path;
    
    
    
    
    public class FileReadAndWrite {
    	public static void main(String [] args) throws Exception{
    		String pathString = "hdfs://192.168.56.171:9000/testRead";
    		URI pathURI = URI.create(pathString);
    		Configuration conf = new Configuration();
    		FileSystem inputFileSystem = FileSystem.get(pathURI, conf);
    		
    /*		InputStream in = inputFileSystem.open(new Path(pathString));		
    		byte[] fileContext = new byte[1024];
    		in.read(fileContext);
    		String str = new String(fileContext);
    		System.out.println(str);*/
    		
    		InputStream in = null;
    		try{
    			in = inputFileSystem.open(new Path(pathString));
    			IOUtils.copyBytes(in, System.out, conf);
    		}
    		finally{
    			IOUtils.closeStream(in);
    		}
    		String writeString = "" +
    				" static FileSystem get(URI uri, Configuration conf)\n" +
    				" --Returns the FileSystem for this URI's scheme and authority.\n" +
    				" FSDataInputStream open(Path f)\n" +
    				" --Opens an FSDataInputStream at the indicated Path.\n" +
    				"static void copyBytes(InputStream in, OutputStream out, Configuration conf)\n"+
    				"--Copies from one stream to another.\n";
    		byte[] stringBuffer = new byte[1024];
    		stringBuffer = writeString.getBytes();
    		
    		Path inputPath = new Path("hdfs://192.168.56.171:9000/testWrite");
    		OutputStream out = inputFileSystem.create(inputPath);
    		out.write(stringBuffer);
    		out.close();
    	
    	}
    
    
    }

    文章结束给大家分享下程序员的一些笑话语录: 真正的程序员喜欢兼卖爆米花,他们利用CPU散发出的热量做爆米花,可以根据米花爆裂的速度听出正在运行什么程序。

    --------------------------------- 原创文章 By
    api和hadoop
    ---------------------------------

  • 相关阅读:
    前端常见跨域解决方案(全)
    小程序动画wx.createAnimation
    判断对象是否有某个属性
    占位符
    vue起航——搭建脚手架
    微信小程序-携带参数转发分享页面
    JS获取地址栏参数
    微信小程序wx:if vs hidden
    小程序websocket(心跳连接)
    初识websocket
  • 原文地址:https://www.cnblogs.com/xinyuyuanm/p/3102204.html
Copyright © 2011-2022 走看看