package cn.itcast.hadoop.hdfs;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;
import java.net.URISyntaxException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;
import org.junit.Before;
import org.junit.Test;
public class HDFSDemo {
// 创建filesystem的实现类(工具类)
FileSystem fs = null;
@Before
public void init() throws IOException, URISyntaxException, Exception {
fs = FileSystem.get(new URI("hdfs://itcast00:9000"), new Configuration(), "root");
}
@Test // 上传文件
public void testUpload() throws IllegalArgumentException, IOException {
// 读取本地系统的文件
InputStream in = new FileInputStream("d://1.txt");
// 在hdfs上创建文件,返回输出流
OutputStream out = fs.create(new Path("/1.mp3"));
// 输入==》输出
IOUtils.copyBytes(in, out, 4096, true);
}
@Test // 上传文件夹
public void testMkdir() throws IllegalArgumentException, IOException {
boolean status1 = fs.mkdirs(new Path("/i6"));
System.out.println(status1);
}
@Test // 下载文件
public void testDownload() throws IllegalArgumentException, IOException {
fs.copyToLocalFile(new Path("/jdk"), new Path("c://safemon//jkd1.7"));
}
@Test // 删除文件
public void testDel() throws IllegalArgumentException, IOException {
boolean flag = fs.delete(new Path("/i.txt"), false);// 是否递归删除
System.out.println(flag);
}
}