前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >快速学习HDFS2.X新特性

快速学习HDFS2.X新特性

作者头像
cwl_java
发布2020-02-19 16:19:20
3020
发布2020-02-19 16:19:20
举报
文章被收录于专栏:cwl_Javacwl_Java

第7章 HDFS2.X新特性

7.1 集群间数据拷贝

  1. scp实现两个远程主机之间的文件复制 scp -r hello.txt root@hadoop103:/user/atguigu/hello.txt // 推 push scp -r root@hadoop103:/user/atguigu/hello.txt hello.txt // 拉 pull scp -r root@hadoop103:/user/atguigu/hello.txt root@hadoop104:/user/atguigu //是通过本地主机中转实现两个远程主机的文件复制;如果在两个远程主机之间ssh没有配置的情况下可以使用该方式。
  2. 采用distcp命令实现两个Hadoop集群之间的递归数据复制
代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$  bin/hadoop distcp
hdfs://haoop102:9000/user/atguigu/hello.txt hdfs://hadoop103:9000/user/atguigu/hello.txt

7.2 小文件存档

在这里插入图片描述
在这里插入图片描述

3. 案例实操 (1)需要启动YARN进程

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ start-yarn.sh

(2)归档文件 把/user/atguigu/input目录里面的所有文件归档成一个叫input.har的归档文件,并把归档后文件存储到/user/atguigu/output路径下。

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ bin/hadoop archive -archiveName input.har –p  /user/atguigu/input   /user/atguigu/output

(3)查看归档

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hadoop fs -lsr /user/atguigu/output/input.har
[atguigu@hadoop102 hadoop-2.7.2]$ hadoop fs -lsr har:///user/atguigu/output/input.har

(4)解归档文件 [atguigu@hadoop102 hadoop-2.7.2]$ hadoop fs -cp har:/// user/atguigu/output/input.har/* /user/atguigu

7.3 回收站

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。

  1. 回收站参数设置及工作机制
在这里插入图片描述
在这里插入图片描述
  1. 启用回收站 修改core-site.xml,配置垃圾回收时间为1分钟。
代码语言:javascript
复制
<property>
   <name>fs.trash.interval</name>
	<value>1</value>
</property>
  1. 查看回收站 回收站在集群中的路径:/user/atguigu/.Trash/….
  2. 修改访问垃圾回收站用户名称 进入垃圾回收站用户名称,默认是dr.who,修改为atguigu用户 [core-site.xml]
代码语言:javascript
复制
<property>
  <name>hadoop.http.staticuser.user</name>
  <value>atguigu</value>
</property>
  1. 通过程序删除的文件不会经过回收站,需要调用moveToTrash()才进入回收站 Trash trash = New Trash(conf); trash.moveToTrash(path);
  2. 恢复回收站数据
代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hadoop fs -mv
/user/atguigu/.Trash/Current/user/atguigu/input    /user/atguigu/input
  1. 清空回收站
代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hadoop fs -expunge

7.4 快照管理

在这里插入图片描述
在这里插入图片描述

2. 案例实操 (1)开启/禁用指定目录的快照功能

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfsadmin -allowSnapshot /user/atguigu/input

[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfsadmin -disallowSnapshot /user/atguigu/input

(2)对目录创建快照

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfs -createSnapshot /user/atguigu/input

通过web访问hdfs://hadoop102:50070/user/atguigu/input/.snapshot/s……// 快照和源文件使用相同数据

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfs -lsr /user/atguigu/input/.snapshot/

(3)指定名称创建快照

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfs -createSnapshot /user/atguigu/input  miao170508

(4)重命名快照

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfs -renameSnapshot /user/atguigu/input/  miao170508 atguigu170508

(5)列出当前用户所有可快照目录

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs lsSnapshottableDir

(6)比较两个快照目录的不同之处

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs snapshotDiff
 /user/atguigu/input/  .  .snapshot/atguigu170508	

(7)恢复快照

代码语言:javascript
复制
[atguigu@hadoop102 hadoop-2.7.2]$ hdfs dfs -cp
/user/atguigu/input/.snapshot/s20170708-134303.027 /user
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-02-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第7章 HDFS2.X新特性
    • 7.1 集群间数据拷贝
      • 7.2 小文件存档
        • 7.3 回收站
          • 7.4 快照管理
          相关产品与服务
          文件存储
          文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档