org.apache.hadoop.hdfs.server.namenode.SafeModeException。。。。Cannot delete。。Name node is in safe mode

本文详细解释了Hadoop分布式文件系统(HDFS)中的安全模式(Safe Mode)。介绍了安全模式的触发条件,如何通过调整dfs.safemode.threshold.pct参数或使用hadoop dfsadmin-safemodeleave命令来控制安全模式,以及安全模式的退出条件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载自:https://blog.youkuaiyun.com/stu756/article/details/49342175

safemode模式 
NameNode在启动的时候首先进入安全模式,如果datanode丢失的block达到一定的比例(1-dfs.safemode.threshold.pct),则系统会一直处于安全模式状态即只读状态。 
dfs.safemode.threshold.pct(缺省值0.999f)表示HDFS启动的时候,如果DataNode上报的block个数达到了元数据记录的block个数的0.999倍才可以离开安全模式,否则一直是这种只读模式。如果设为1则HDFS永远是处于SafeMode。 
下面这行摘录自NameNode启动时的日志(block上报比例1达到了阀值0.9990) 
The ratio of reported blocks 1.0000 has reached the threshold 0.9990. Safe mode will be turned off automatically in 18 seconds. 
hadoop dfsadmin -safemode leave 
有两个方法离开这种安全模式 
1. 修改dfs.safemode.threshold.pct为一个比较小的值,缺省是0.999。 
2. hadoop dfsadmin -safemode leave命令强制离开 

Safe mode is exited when the minimal replication condition is reached, plus an extension 
time of 30 seconds. The minimal replication condition is when 99.9% of the blocks in 
the whole filesystem meet their minimum replication level (which defaults to one, and 
is set by dfs.replication.min). 
安全模式的退出前提 - 整个文件系统中的99.9%(默认是99.9%,可以通过dfs.safemode.threshold.pct设置)的Blocks达到最小备份级别(默认是1,可以通过dfs.replication.min设置)。 
dfs.safemode.threshold.pct float 0.999 
The proportion of blocks in the system that must meet the minimum 
replication level defined by dfs.rep lication.min before the namenode 
will exit safe mode. Setting 
this value to 0 or less forces the name-node not to start in safe mode. 
Setting this value to more than 1 means the namenode never exits safe 
mode. 
----------------------------- 
用户可以通过dfsadmin -safemode value 来操作安全模式,参数value的说明如下: 
enter - 进入安全模式 
leave - 强制NameNode离开安全模式 
get - 返回安全模式是否开启的信息 
wait - 等待,一直到安全模式结束。

当您在使用 Hadoop 集群时遇到 `PriviledgedActionException` 错误,提示 `SafeModeException: Cannot create directory /tmp. Name node is in safe mode.` 这表示名称节点(NameNode)正处于安全模式(safe mode)。在这种状态下,HDFS 系统不允许对文件系统进行修改操作(例如创建目录、删除文件等),只能执行读取操作。 ### 安全模式的作用 安全模式是一种保护机制,在集群启动初期或者检测到数据块副本不足的情况下启用。它会暂时冻结文件系统的写入功能,以便完成必要的健康检查或修复工作,比如平衡数据块分布、等待丢失的 DataNodes 回归等。 ### 解决方案 1. **手动离开安全模式** 如果确认集群已经稳定运行,并不需要额外的安全措施,则可以直接通过以下命令让 NameNode 退出安全模式: ```bash hdfs dfsadmin -safemode leave ``` 执行完这条指令后,如果一切正常的话,就可以开始正常的写入操作了。 2. **查看当前状态** 在采取行动前,先查询一下 NameNode 是否真的处于安全模式以及更多详细信息: ```bash hdfs dfsadmin -safemode get ``` 3. **调整阈值参数(非推荐)** 默认情况下,HDFS 会在达到一定比例的数据块恢复后自动退出安全模式。如果您希望改变这一标准,可以在 `hdfs-site.xml` 中调节相关配置项,但这通常并不建议新手轻易尝试。 相关配置示例: ```xml <property> <name>dfs.safemode.threshold.pct</name> <value>0.999f</value> <!-- 设置百分比 --> </property> <property> <name>dfs.safemode.min.datanodes</name> <value>3</value> <!-- 最小DataNode数 --> </property> ``` 4. **重启服务**(最后的办法) 若上述方法均无效,您可以考虑停止并重新启动整个 Hadoop 服务链路,不过在此之前一定要做好充分准备以防万一发生不可逆损失风险事件的发生概率降到最低限度范围内为止才行啊朋友们! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值