HDFS之NameNode

NameNode&Secondary NameNode工作机制

1)第一阶段:namenode启动

1)第一次启动namenode格式化后创建fsimage和edits文件。如果不是第一次启动,直接加载编辑日志和镜像文件到内存。

2客户端对元数据进行增删改的请求

3namenode记录操作日志,更新滚动日志

4namenode在内存中对数据进行增删改查

2)第二阶段:Secondary NameNode工作

1Secondary NameNode询问namenode是否需要checkpoint直接带回namenode是否检查结果。

2Secondary NameNode请求执行checkpoint。

3namenode滚动正在写的edits日志

4)将滚动前的编辑日志和镜像文件拷贝到Secondary NameNode

5Secondary NameNode加载编辑日志和镜像文件到内存,并合并。

6生成新的镜像文件fsimage.chkpoint

7拷贝fsimage.chkpoint到namenode

8namenode将fsimage.chkpoint重新命名成fsimage

3)web端访问SecondaryNameNode

1)启动集群

2)浏览器中输入:http://hadoop102:50090/status.html

3)查看SecondaryNameNode信息

4chkpoint检查时间参数设置

1)通常情况下,SecondaryNameNode每隔一小时执行一次

[hdfs-default.xml]

<property>

  <name>dfs.namenode.checkpoint.period</name>

  <value>3600</value>

</property>

2)一分钟检查一次操作次数,当操作次数达到1百万时,SecondaryNameNode执行一次。

<property>

  <name>dfs.namenode.checkpoint.txns</name>

  <value>1000000</value>

<description>操作动作次数</description>

</property>

 

<property>

  <name>dfs.namenode.checkpoint.check.period</name>

  <value>60</value>

<description> 1分钟检查一次操作次数</description>

</property>

 

 

镜像文件和编辑日志文件

 

1概念

namenode被格式化之后,将在/opt/module/hadoop-2.7.2/data/tmp/dfs/name/current目录中产生如下文件

edits_0000000000000000000

fsimage_0000000000000000000.md5

seen_txid

VERSION

1Fsimage文件:HDFS文件系统元数据的一个永久性的检查点,其中包含HDFS文件系统的所有目录和文件idnode的序列化信息。 

2Edits文件:存放HDFS文件系统的所有更新操作的路径,文件系统客户端执行的所有写操作首先会被记录到edits文件中。 

3seen_txid文件保存的是一个数字,就是最后一个edits_的数字

4每次Namenode启动的时候都会将fsimage文件读入内存,并从00001开始到seen_txid中记录的数字依次执行每个edits里面的更新操作,保证内存中的元数据信息是最新的、同步的,可以看成Namenode启动的时候就将fsimageedits文件进行了合并

2oiv查看fsimage文件

1查看oiv和oev命令

[atguigu@hadoop102 current]$ hdfs

oiv                  apply the offline fsimage viewer to an fsimage

oev                  apply the offline edits viewer to an edits file

2)基本语法

hdfs oiv -p 文件类型 -i镜像文件 -o 转换后文件输出路径

3)案例实操

[atguigu@hadoop102 current]$ pwd

/opt/module/hadoop-2.7.2/data/tmp/dfs/name/current

 

[atguigu@hadoop102 current]$ hdfs oiv -p XML -i fsimage_0000000000000000025 -o /opt/module/hadoop-2.7.2/fsimage.xml

 

[atguigu@hadoop102 current]$ cat /opt/module/hadoop-2.7.2/fsimage.xml

将显示xml文件内容拷贝到eclipse中创建的xml文件中,并格式化

3)oev查看edits文件

(1)基本语法

hdfs oev -p 文件类型 -i编辑日志 -o 转换后文件输出路径

(2)案例实操

[atguigu@hadoop102 current]$ hdfs oev -p XML -i edits_0000000000000000012-0000000000000000013 -o /opt/module/hadoop-2.7.2/edits.xml

[atguigu@hadoop102 current]$ cat /opt/module/hadoop-2.7.2/edits.xml

将显示xml文件内容拷贝到eclipse中创建的xml文件中,并格式化

SecondaryNameNode目录结构

 

Secondary NameNode用来监控HDFS状态的辅助后台程序,每隔一段时间获取HDFS元数据的快照。

 

在/opt/module/hadoop-2.7.2/data/tmp/dfs/namesecondary/current这个目录中查看SecondaryNameNode目录结构。

 

edits_0000000000000000001-0000000000000000002

fsimage_0000000000000000002

fsimage_0000000000000000002.md5

VERSION

 

SecondaryNameNode的namesecondary/current目录和主namenodecurrent目录的布局相同。

 

好处:在主namenode发生故障时(假设没有及时备份数据),可以SecondaryNameNode恢复数据

 

方法一:将SecondaryNameNode中数据拷贝到namenode存储数据的目录;

 

方法二:使用-importCheckpoint选项启动namenode守护进程,从而将SecondaryNameNode用作新的主namenode。

集群安全模式操作

(1)bin/hdfs dfsadmin -safemode get (功能描述:查看安全模式状态

2bin/hdfs dfsadmin -safemode enter   (功能描述:进入安全模式状态

3bin/hdfs dfsadmin -safemode leave (功能描述:离开安全模式状态

4bin/hdfs dfsadmin -safemode wait (功能描述:等待安全模式状态

 

posted @ 2019-07-09 16:55  孤身!  阅读(1887)  评论(0编辑  收藏  举报