hadoop入门之通过java代码实现将本地文件上传到hadoop的文件系统
第一步:首先搭建java的编译环境。创建一个Java Project工程,名为upload。
第二步:选中所需的Jar包。
选中JRE System Library 选择BuildPath Configure Build Path 选择hadoop相应的jar包。
通过Add External JARS --〉Hadoop-0.20.2下所有的jar包以及lib下所有的jar包。OK。操作步骤如图:
Hadoop-0.20.2下所有的jar包。
lib下的所有jar包。
第三步:创建class名为UploadFile
第四步:编写代码。
package upload;</p> <p>import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;</p> <p>
public class UploadFile {</p> <p> public static void main(String[] args) {
try {
String localStr = args[0];
String dst = args[1];
//in对应的是本地文件系统的目录
InputStream in = new BufferedInputStream(new FileInputStream(localStr));
Configuration conf = new Configuration();
//获得hadoop系统的连接
FileSystem fs = FileSystem.get(URI.create(dst),conf);
//out对应的是Hadoop文件系统中的目录
OutputStream out = fs.create(new Path(dst));
IOUtils.copyBytes(in, out, 4096,true//4096是4k字节
System.out.println("success");
} catch (Exception e) {
System.out.println(e.toString());
}
}
}
第五步:在Run Configuration里面设置两个参数,并执行。
点击 Run Configuration
在Java Application中设置 Project和MainClass
Arguments 加两个参数/home/cui/xxxx hdf://cui:9000/xxx Applay Run
第六步:查看结果。
显示运行成功。
在hadoop文件系统中已经看到了hadoop-0.20.2.tar.gz了。
至此文件通过代码上传成功!
将代码打包成jar文件,并测试。
1. 在Run Configurations里面命名为uploadfile。
2. 右击工程,执行Export,选择Runnable JAR file。点击下一步。
3. 选择刚才的configuration uploadfile,选择导出路径/home/cui。命名为upload.jar
点击下一步,导出成功。
4. 通过java命令执行。
5. 通过浏览器查看。
upload_hdfs.jar 已经存在。
相关文章
- 近日做了一个简单的活,就是把一个phpcms建的网站整站迁移到另一个空间上。原本应该是很简单的事情,无奈却处处碰壁,遇到各种问题。终于在今天把所有问题解决,特撰写此文2008-10-08
webstorm/phpstorm配置连接ftp快速进行文件比较(上传下载/同步)操作
Phpstorm除了能直接打开localhost文件之外,还可以连接FTP,除了完成正常的数据传递任务之外,还可以进行本地文件与服务端文件的异同比较,同一文件自动匹配目录上传,下载2013-12-23- 新版CuteFTP内置计划任务表模块,能够按用户预先指定的日期和时间,自动拨号、上传文件并自动断线(总之就是“全自动”)。2011-04-11
- 如果你要向虾米音乐上传自己的专辑,或者自己收藏喜爱的专辑,那么需要用到这个虾米上传工具--虾米2014-03-14
- FTP有时候出现无法上传或出现报错连接不上的情况,针对这个问题,下面有个不错的解决方法,大家可以参考下2014-01-30
- 手机QQ群文件怎么上传?手机QQ可以在群里面分享文件,视频等,不过要怎么操作呢?下面就让小编简单的为大家实例讲解一下,很简单的哦2014-03-01
- 百度云网盘可以上传文件夹吗?百度网盘能直接上传文件夹吗?针对百度云网盘上传文件夹的问题,本文就为大家图文介绍百度云网盘上传文件夹的步骤,有兴趣的朋友们可以了解下2014-12-12
爱思助手中怎么上传SHSH文件?爱思助手上传shsh图文教程
苹果设备在降级时,最关键的就是shsh,当你需要使用爱思助手降级刷机,爱思服务器没有你刷机所使用的SHSH,此时你就可以使用“上传SHSH”的功能,上传所需要的SHSH进行刷机2014-11-21- 迅雷后台是查看其它网络上传数据的管理器,这样就可以限制其它用户上传速度2014-04-24
Cyberduck如何使用?Cyberduck上传文件图文教程
Cyberduck是一款用来联ftp服务器的软件,容许同时打开多个窗口,于是可同时连到多个服务器工作。当然也附书签,支持运行publicfile(FTP)服务器的EPFL文件列表,那么Cyber2016-07-22
最新评论