hdfs 安全模式的理解
安全模式是hadoop的一种保护机制,用于保证集群中的数据块的安全性。
当集群启动的时候,会首先进入安全模式:当系统处于安全模式时会去检查数据块的完整性
假设我们设置的副本数(即参数dfs.replication)是3,那么在datanode上就应该有3个副本存在,假设只存在1个副本,那么比例就是1/3=0.333,这个比例就是副本率;在配置文件hdfs-default.xml中定义了一个最小的副本的副本率0.999,为默认参数:
<property>
<name>dfs.safemode.threshold.pct</name>
<value>0.999f</value>
</property>
我们的副本率0.333明显小于0.999,因此系统会自动的复制副本到其他的dataNode,使得副本率不小于0.999;但是如果系统中有5个副本,超过我们设定的3个副本,那么系统也会删除多余的2个副本
安全模式的影响
1.在安全模式下,不允许客户端进行任何修改文件的操作,包括上传文件,删除文件,重命名,创建文件夹等操作。
虽然不能进行修改文件的操作,但是可以浏览目录结构、查看文件内容的,在命令行下是可以控制安全模式的进入、退出和查看的
2.安全模式是hadoop的一种保护机制,在启动时,最好是等待集群自动退出,然后进行文件操作。
正常情况下,安全模式会运行一段时间自动退出的,只需要我们稍等一会就行了,到底等多长时间呢,我们可以通过50070端口查看安全模式退出的剩余时间
安全模式的相关命令
在命令行下是可以控制安全模式的进入、退出和查看的。
命令 hadoop fs -safemode get
查看安全模式状态
命令 hadoop fs -safemode enter
进入安全模式状态
命令 hadoop fs -safemode leave
离开安全模式