Hadoop-动态刷新hdfs/yarn配置

博客介绍了Hadoop动态刷新HDFS和YARN配置的方法。在修改Hadoop配置后,为让其立即生效且不影响线上任务,可执行相应命令。对于HA集群,需在两个NameNode节点上分别执行刷新HDFS和YARN配置的操作。

@羲凡——只为了更好的活着

Hadoop-动态刷新hdfs/yarn配置

在很多时候,修改了hadoop的配置后,希望立即生效,但是线上还有任务在执行,不能重启,可以执行以下命令让修改后的hdfs/yarn配置生效

1、动态刷新hdfs配置

如果是HA集群则在两个namenode节点上执行

hdfs dfsadmin -fs hdfs://nn1:9000 -refreshSuperUserGroupsConfiguration
hdfs dfsadmin -fs hdfs://nn2:9000 -refreshSuperUserGroupsConfiguration
2、动态刷新yarn配置

如果是HA集群则在两个namenode节点上执行

yarn rmadmin -fs hdfs://nn1:9000 -refreshSuperUserGroupsConfiguration
yarn rmadmin -fs hdfs://nn2:9000 -refreshSuperUserGroupsConfiguration

====================================================================
@羲凡——只为了更好的活着

若对博客中有任何问题,欢迎留言交流

### Hadoop YARN 中 `yarn.application.classpath` 配置项的作用 在 Hadoop YARN 中,`yarn.application.classpath` 是一个重要的配置参数,用于定义应用程序可以访问的类路径(classpath)。此配置项的主要作用是确保 YARN 上运行的应用程序能够找到所需的库文件和依赖项。具体来说: - **作用**: 此配置项指定了一组默认的类路径,这些路径会被添加到所有提交给 YARN 的应用程序的类加载器中[^1]。这使得用户无需手动提供所有的依赖库即可正常运行作业。 - **值的组成**: 类路径通常由多个目录或 JAR 文件路径组成,通过逗号分隔。常见的路径包括但不限于以下内容: - `$HADOOP_CONF_DIR`: 存储 HadoopYARN 配置文件的目录。 - `$HADOOP_COMMON_HOME/share/hadoop/common/*`: 包含通用模块的 JAR 文件。 - `$HADOOP_HDFS_HOME/share/hadoop/hdfs/*`: 包含 HDFS 相关模块的 JAR 文件。 - `$HADOOP_YARN_HOME/share/hadoop/yarn/*`: 包含 YARN 相关模块的 JAR 文件。 - `$HADOOP_MAPRED_HOME/share/hadoop/mapreduce/*`: 包含 MapReduce 相关模块的 JAR 文件。 以下是典型的 `yarn.application.classpath` 值示例: ```properties $HADOOP_CONF_DIR, $HADOOP_COMMON_HOME/share/hadoop/common/*, $HADOOP_COMMON_HOME/share/hadoop/common/lib/*, $HADOOP_HDFS_HOME/share/hadoop/hdfs/*, $HADOOP_YARN_HOME/share/hadoop/yarn/*, $HADOOP_YARN_HOME/share/hadoop/yarn/lib/* ``` 上述路径中的通配符 (`*`) 表示该目录下的所有 JAR 文件都会被包含在类路径中[^4]。 --- ### 如何验证配置是否生效? 可以通过以下方式确认 `yarn.application.classpath` 是否正确设置并生效: 1. 使用命令 `yarn classpath` 查看当前有效的类路径列表。 2. 提交一个简单的测试任务(如 WordCount),观察日志中是否有找不到依赖的错误提示。 如果发现某些必要的库未被加载,则可能需要调整 `yarn-site.xml` 文件中的 `yarn.application.classpath` 参数,并重新启动 YARN 服务以使更改生效。 --- ### 示例代码:修改 `yarn-site.xml` 并重启 YARN 编辑 `yarn-site.xml` 文件,添加或更新如下属性: ```xml <property> <name>yarn.application.classpath</name> <value>$HADOOP_CONF_DIR,$HADOOP_COMMON_HOME/share/hadoop/common/*,$HADOOP_COMMON_HOME/share/hadoop/common/lib/*,$HADOOP_HDFS_HOME/share/hadoop/hdfs/*,$HADOOP_YARN_HOME/share/hadoop/yarn/*,$HADOOP_YARN_HOME/share/hadoop/yarn/lib/*</value> </property> ``` 保存后执行以下操作以应用新配置: ```bash # 刷新 YARN 配置 sudo systemctl restart hadoop-yarn-resourcemanager.service sudo systemctl restart hadoop-yarn-nodemanager.service ``` 或者直接使用脚本停止再启动 YARN: ```bash stop-yarn.sh start-yarn.sh ``` --- ### 注意事项 - 如果集群中有自定义开发的任务或第三方工具集成需求,需额外将相关依赖加入到 `yarn.application.classpath` 中[^3]。 - 当前版本为 Hadoop 3.4.0,不同版本间的默认类路径可能会有所差异,请根据实际环境进行适配。 --- ####
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值