Fork me on GitHub

Hadoop 存档

  每个文件均按块存储,每个块的元数据存储在namenode的内存中,因此hadoop存储小文件会非常低效。因为大量的小文件会耗尽namenode中的大部分内存。但注意,存储小文件所需要的磁盘容量和存储这些文件原始内容所需要的磁盘空间相比也不会增多。例如,一个1MB的文件以大小为128MB的块存储,使用的是1MB的磁盘空间,而不是128MB。

  Hadoop存档文件或HAR文件,是一个更高效的文件存档工具,它将文件存入HDFS块,在减少namenode内存使用的同时,允许对文件进行透明的访问。具体说来,Hadoop存档文件可以用作MapReduce的输入。


案例实操
1.需要启动yarn进程
[liucw@hadoop102 hadoop-2.7.2]$ start-yarn.sh

2.归档文件
  归档成一个叫做xxx.har的文件夹,该文件夹下有相应的数据文件。Xx.har目录是一个整体,该目录看成是一个归档文件即可。
[liucw@hadoop102 hadoop-2.7.2]$ bin/hadoop archive -archiveName myhar.har -p /user/liucw /user/my

3.查看归档

1
2
3
[liucw@hadoop102 hadoop-2.7.2]$ hadoop fs -lsr /user/my/myhar.har
[liucw@hadoop102 hadoop-2.7.2]$ hadoop fs -lsr har:///myhar.har

4.解归档
[liucw@hadoop102 hadoop-2.7.2]$ hadoop fs -cp har:/// user/my/myhar.har /* /user/liucw

-----------------本文结束,感谢您的阅读-----------------