HDFS
文章目录
- HDFS
- 1、Shell 操作
- 上传
- 下载
- 直接操作(和Linux命令功能一样)
- 2、API 操作
- 准备工作
- 文件上传
- 文件下载
- 修改文件名称
- 删除文件和目录
- 文件详情查看
- 文件和文件夹判断
- 修改参数方法
- 参数优先级
1、Shell 操作
上传
- -moveFromLocal:从本地剪切粘贴到 HDFS
hadoop fs -moveFromLocal 本地文件 HDFS目录
- -copyFromLocal:从本地文件系统中拷贝文件到 HDFS 路径去
hadoop fs -copyFromLocal 本地文件 HDFS目录
- -put:等同于 copyFromLocal,生产环境更习惯用 put
hadoop fs -put 本地文件 HDFS目录
- -appendToFile:追加一个文件到已经存在的文件末尾
hadoop fs -appendToFile 本地文件 HDFS目录
下载
- -copyToLocal:从 HDFS 拷贝到本地
hadoop fs -copyToLocal HDFS目录文件 本地目录
- -get:等同于 copyToLocal,生产环境更习惯用 get
hadoop fs -get HDFS目录文件 本地目录
直接操作(和Linux命令功能一样)
- -ls: 显示目录信息
- -cat:显示文件内容
- -chmod、-chown:Linux 文件系统中的用法一样,修改文件所属权限
- -mkdir:创建路径
- -cp:从 HDFS 的一个路径拷贝到 HDFS 的另一个路径
- -mv:在 HDFS 目录中移动文件
- -tail:显示一个文件的末尾 1kb 的数据
- -rm:删除文件或文件夹
- -rm -r:递归删除目录及目录里面内容
- -du: 统计文件夹的大小信息
-
hadoop fs -du -s -h HDFS目录
(列出该目录的大小信息) -
hadoop fs -du -h HDFS目录
(列出该目录里面文件的大小信息)
- -setrep:设置 HDFS 中文件的副本数量(将该文件的副本数设置为 10 个)
hadoop fs -setrep 10 HDFS目录文件
2、API 操作
准备工作
- 添加依赖:创建Maven工程,添加依赖(pom.xml)
<dependency>
<!-- 版本号跟自己的Hadoop版本对应 -->
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-client</artifactId>
<version>3.1.4</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.30</version>
</dependency>
- 添加日志:log4j.properties
log4j.rootLogger=INFO, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=target/spring.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n
文件上传
FileSystem.copyFromLocalFile(...)
@Test
public void testCopyFromLocalFile() throws IOException, InterruptedException, URISyntaxException {
// 1 获取文件系统
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 上传文件
fs.copyFromLocalFile(new Path("D:\\fzk.txt"), new Path("/fzk"));
// 3 关闭资源
fs.close();
}
文件下载
FileSystem.copyToLocalFile(...)
@Test
public void testCopyToLocalFile() throws IOException, InterruptedException, URISyntaxException {
// 1 获取文件系统
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 执行下载操作
// boolean delSrc 指是否将原文件删除
// Path src 指要下载的文件路径
// Path dst 指将文件下载到的路径
// boolean useRawLocalFileSystem 是否开启文件校验
fs.copyToLocalFile(false, new Path("/xiyou/huaguoshan/sunwukong.txt"), new Path("d:/sunwukong2.txt"), true);
// 3 关闭资源
fs.close();
}
修改文件名称
FileSystem.rename(...)
@Test
public void testRename() throws IOException, InterruptedException, URISyntaxException{
// 1 获取文件系统
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 修改文件名称
fs.rename(new Path("/xiyou/sunwukong.txt"), new Path("/xiyou/meihouwang.txt"));
// 3 关闭资源
fs.close();
}
删除文件和目录
FileSystem.delete(...)
@Test
public void testDelete() throws IOException, InterruptedException, URISyntaxException{
// 1 获取文件系统
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 执行删除
fs.delete(new Path("/xiyou"), true);
// 3 关闭资源
fs.close();
}
文件详情查看
- 查看文件名称、权限、长度、块信息
@Test
public void testListFiles() throws IOException, InterruptedException, URISyntaxException {
// 1 获取文件系统
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 获取文件详情
RemoteIterator<LocatedFileStatus> listFiles = fs.listFiles(new Path("/"), true);
while (listFiles.hasNext()) {
LocatedFileStatus fileStatus = listFiles.next();
System.out.println("========" + fileStatus.getPath() + "=========");
System.out.println(fileStatus.getPermission()); //权限
System.out.println(fileStatus.getOwner()); //拥有者
System.out.println(fileStatus.getGroup()); //组
System.out.println(fileStatus.getLen()); //长度
System.out.println(fileStatus.getModificationTime()); //修改时间
System.out.println(fileStatus.getReplication()); //文件存存储的副本数
System.out.println(fileStatus.getBlockSize()); //块的大小
System.out.println(fileStatus.getPath().getName()); //名称
// 获取块信息
BlockLocation[] blockLocations = fileStatus.getBlockLocations();
System.out.println(Arrays.toString(blockLocations)); //文件所在的块
}
// 3 关闭资源
fs.close();
}
文件和文件夹判断
FileSystem.isFile()
@Test
public void testListStatus() throws IOException, InterruptedException, URISyntaxException {
// 1 获取文件配置信息
Configuration configuration = new Configuration();
//(URI uri) 和 (String user) 两个参数按照自己的配置相应的修改
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
// 2 判断是文件还是文件夹
FileStatus[] listStatus = fs.listStatus(new Path("/"));
for (FileStatus fileStatus : listStatus) {
// 如果是文件
if (fileStatus.isFile()) {
System.out.println("文件:" + fileStatus.getPath().getName());
} else {
System.out.println("目录:" + fileStatus.getPath().getName());
}
}
// 3 关闭资源
fs.close();
}
修改参数方法
- 1、客户端代码中设置的值:
Configuration.set(key, value)
// 1 获取文件系统
Configuration configuration = new Configuration();
//设置 dfs.replication 的数量为 2
configuration.set("dfs.replication", "2");
FileSystem fs = FileSystem.get(new URI("hdfs://192.168.37.151:8020"), configuration, "root");
- 2、ClassPath 下的用户自定义配置文件
- 将 hdfs-site.xml 拷贝到项目的 resources 资源目录下
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
<configuration>
<!-- 设置 dfs.replication 的数量为 1 -->
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
</configuration>
- 3、然后是服务器的自定义配置(xxx-site.xml)
- 4、服务器的默认配置(xxx-default.xml)
参数优先级
- 优先级从高到低
- 客户端代码中设置的值
- ClassPath 下的用户自定义配置文件
- 然后是服务器的自定义配置(xxx-site.xml)
- 服务器的默认配置(xxx-default.xml)