Hadoop 停止服务时报错?一招搞定 HDFS & YARN 用户权限问题!

一、问题背景

今天在停止 Hadoop 服务时,遇到了如下报错:

看起来是 Hadoop 组件无法以 root 身份运行,而缺少了相应的 HDFS 和 YARN 用户。

二、问题分析

Hadoop 的 HDFS 和 YARN 默认需要以 非 root 用户 运行,但我的系统中并没有 hdfsyarn 这两个用户,导致无法正常执行 stop-all.sh 脚本。

三、解决方案

为了让 Hadoop 组件能够在 root 用户下运行,我们需要手动指定相应的环境变量。

修改 Hadoop 相关脚本:

/hadoop/sbin/ 目录下,修改以下文件:

1. 修改 start-dfs.shstop-dfs.sh

在文件顶部添加如下内容:

HDFS_DATANODE_USER=root
HADOOP_SECURE_DN_USER=hdfs
HDFS_NAMENODE_USER=root
HDFS_SECONDARYNAMENODE_USER=root
2. 修改 start-yarn.shstop-yarn.sh

在文件顶部添加如下内容:

YARN_RESOURCEMANAGER_USER=root
HADOOP_SECURE_DN_USER=yarn
YARN_NODEMANAGER_USER=root

这样,Hadoop 组件将在 root 用户下运行,不会再因为缺少 hdfsyarn 用户而报错。

四、总结

如果你的 Hadoop 在停止或启动时出现 “Attempting to operate on hdfs/yarn as root” 相关报错,大概率是缺少 HDFS 和 YARN 运行用户。

解决方法就是手动在 start-dfs.shstop-dfs.shstart-yarn.shstop-yarn.sh 文件顶部添加环境变量,使其允许以 root 身份运行。

这样一来,我们就可以顺利启动和停止 Hadoop 了!🎉


希望这篇文章能帮到你,欢迎大家点赞,收藏,关注,转发哦!🚀

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值