一个渺小的投入就会带来微小的渐变

集群平安模式

为什么呈现集群平安模式呢?

Namenode启动时,首先将镜像文件载人内存,并执行编辑日志中的各项操作。一旦在內存中胜利建设文件系统元数据的映像,则创立一个新的Fsimage文件和一个空的编辑日志。此时, Namenode开始监听Datanode申请。这个过程期间, Namenode始终运行在平安模式,即NameNode的文件系统对于客户端来说是只读的

其实平安模式就是集群数据都还没筹备好时候的一个爱护机制

DataNode启动产生的事件

零碎中的数据块的地位并不是由 NameNode保护的,而是以块列表的模式存储在 DataNode中。在零碎的失常操作期间, NameNode会在内存中保留所有块地位的映射信息。在平安模式下,各个 DataNode会向NameNode发送最新的块列表信息, NameNode理解到足够多的块地位信息之后,即可髙效运行文件系统

这个足够多是多少呢?99.9%

平安模式退出的判断

如果满足“最小正本条件”, NameNode会在30秒钟之后就退出平安模式。所谓的最小正本条件指的是在整个文件系统中99.9%的块满足最小正本级别(默认值:dfs.replication.min=1)。在启动一个刚刚格式化的HDFS集群时,因为零碎中还没有任何块,所以 Namenode不会进入平安模式。

集群平安模式下的操作

  • hdfs dfsadmin -safemode get (性能形容:查看平安模式状态)
  • hdfs dfsadmin -safemode enter (性能形容:进入平安模式状态)
  • hdfs dfsadmin -safemode leave (性能形容:来到平安模式状态)
  • hdfs dfsadmin -safemode wait (性能形容:期待平安模式状态)
    • 相干材料