博客
关于我
YARN环境中应用程序JAR包冲突问题的分析及解决
阅读量:797 次
发布时间:2023-04-04

本文共 588 字,大约阅读时间需要 1 分钟。

Hadoop on YARN 环境下,MapReduce程序运行时JAR包查找的原理以及解决JAR包冲突的方法

在Hadoop框架中,预置的JAR包会优先被加载,这可能导致与应用程序的JAR包版本冲突。以下是解决问题的详细步骤。

一、问题分析我的MR程序使用jackson库1.9.13版本,而Hadoop预置1.8.8版本,导致无法使用新接口。运行时出现错误:org.codehaus.jackson.JsonNode.asText()。

二、YARN执行流程

  • AppMaster启动并分配任务到NodeManager。
  • NodeManager下载并运行Container。
  • Container通过launch_container.sh脚本启动,JVM CLASSPATH优先加载Hadoop预置JAR包。
  • 三、解决方法

  • 调整CLASSPATH顺序,将应用JAR包目录添加到前面。
  • 在运行命令中使用-libjars参数,将应用依赖JAR包打包。
  • 四、代码修改在MRApps类中修改YARN_APPLICATION_CLASSPATH配置,确保应用JAR包优先加载。

    五、优化方案

  • 读取源码,理解YARN如何设置CLASSPATH。
  • 修改配置,调整JAR包加载顺序。
  • 使用-libjars参数打包依赖JAR包。
  • 通过以上方法,可以确保应用程序的JAR包优先加载,解决冲突问题。

    转载地址:http://gcrfk.baihongyu.com/

    你可能感兴趣的文章
    mysql中null和空字符串的区别与问题!
    查看>>
    MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
    查看>>
    MYSQL中TINYINT的取值范围
    查看>>
    MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
    查看>>
    Mysql中varchar类型数字排序不对踩坑记录
    查看>>
    MySQL中一条SQL语句到底是如何执行的呢?
    查看>>
    MySQL中你必须知道的10件事,1.5万字!
    查看>>
    MySQL中使用IN()查询到底走不走索引?
    查看>>
    Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
    查看>>
    MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
    查看>>
    mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
    查看>>
    mysql中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>
    MySQL中地理位置数据扩展geometry的使用心得
    查看>>
    Mysql中存储引擎简介、修改、查询、选择
    查看>>
    Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
    查看>>
    mysql中实现rownum,对结果进行排序
    查看>>
    mysql中对于数据库的基本操作
    查看>>
    Mysql中常用函数的使用示例
    查看>>