hadoop使用LinuxContainerExecutor后使用root用户提交任务报错--源码修改

在Hadoop3.2.1版本中,配置cgroup进行YARN CPU资源隔离后,使用root用户提交任务失败。源码检查显示,LinuxContainerExecutor(LCE)禁止root用户提交任务。解决方法涉及修改源码并重新编译。

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

问题描述

在hadoop3.2.1的版本中,配置cgroup对yarn的cpu资源进行隔离之后,发现,使用root用户在yarn上提交任务时,无法提交成功,并会报错:

Runing as root is not allowed!

最后将这些错误在源码中搜索发现以下内容:

/**
 * Is the user a real user account?
 * Checks:
 *   1. Not root
 *   2. UID is above the minimum configured.
 *   3. Not in banned user list
 * Returns NULL on failure
 */
struct passwd* check_user(const char *user) {
  if (strcmp(user, "root") == 0) {
    fprintf(LOGFILE, "Running as root is not allowed\n");
    fflush(LOGFILE);
    return NULL;
  }  

原来是在源码里写明了在开启了LCE(LinuxContainerExecutor)后。LCE不能使用root用户提交任务,会检查user信息。

问题本质

user信息的检查会在org.apache.hadoop.mapreduce.job的init阶段执行。
Container启动的过程大致如下:
资源本地化——启动container——运行container——资源回收

问题解决

在\hadoop-3.2.1-src\hadoop-yarn-project\hadoop-yarn\hadoop-yarn-server\hadoop-yarn-server-nodemanager\src\main\native\container-executor\impl\container-executor.c 中,找到上述的代码片段,并注释如下:

/**
 * Is the user a real user account?
 * Checks:
 *   1. Not root
 *   2. UID is above the minimum configured.
 *   3. Not in banned user list
 * Returns NULL on failure
 */
struct passwd* check_user(const char *user) {
//  if (strcmp(user, "root") == 0) {
//    fprintf(LOGFILE, "Running as root is not allowed\n");
//    fflush(LOGFILE);
//    return NULL;
//  }
  char *min_uid_str = get_value(MIN_USERID_KEY);
  int min_uid = DEFAULT_MIN_USERID;
  if (min_uid_str != NULL) {
    char *end_ptr = NULL; 
 。。。。。。
 。。。。

然后将代码重新编译即可。

<think>嗯,用户这次明确询问学习AUTOSAR所需的基础知识,看来是准备系统学习汽车软件架构。之前虽然详细讲解过BSW学习路线,但用户更关注前置技能,说明可能是刚接触这个领域的工程师或学生。 用户特意强调要参考之前的对话,注意到上次提到的MCAL、通信栈等术语这次可以复用。不过需要更基础的解释,比如"实时操作系统"这样的概念对新手可能不够友好,应该拆解成更具知识点。 从用户追问预备知识的行为看,ta可能正在评估自身知识储备是否足够学习AUTOSAR。需要明确区分硬性要求和加分技能:C语言和嵌入式系统是门槛,而CAN总线协议这类属于应用场景知识。特别要注意提醒数学要求——虽然AUTOSAR开发不直接涉及复杂数学,但状态机等概念需要逻辑思维。 上次推荐的B站课程《AutoSAR从入门到精通》依然适用,但这次要补充说明该课程第一章就讲解预备知识。GitHub的arccore项目对初学者可能偏难,换成更基础的AUTOSAR文档链接更实用。 考虑到用户连续两次询问学习路径,应该设计成渐进式清单。把"核心基础知识"和"扩展知识"分开列项,避免给初学者压力。最后的相关问题特意加入"是否需要学习C++",因为很多汽车电子工程师有C基础但可能不熟悉面向对象。</think>以下是学习AUTOSAR所需的**系统化基础知识系**,分为核心基础与扩展知识两大模块,结合汽车电子开发实际需求整理: --- ### 一、核心基础知识 #### 1. **嵌入式系统基础** - **C语言编程**: - 掌握指针、结构、内存管理(堆/栈) - 理解`volatile`、`const`等硬件相关关键字[^1] - **微控制器(MCU)架构**: - ARM Cortex-M/R系列(如STM32、NXP S32K) - 中断控制器(NVIC)、时钟系统、外设寄存器操作 #### 2. **汽车通信协议** | 协议 | 关键特性 | 学习重点 | |---------|--------------------------|------------------------------| | **CAN** | 差分信号、仲裁机制 | 标准帧/扩展帧、ID过滤规则[^2] | | **LIN** | 主从结构、低成本 | 调度表设计、诊断帧 | | **Ethernet** | 高速通信(100Mbps+) | TCP/IP协议栈、SOME/IP协议[^2] | #### 3. **实时操作系统(RTOS)概念** - 任务调度机制(优先级抢占/时间片轮转) - 同步机制:信号量、互斥锁、事件标志 - 内存保护(MPU)与可信任务设计[^3] --- ### 二、扩展知识(提升开发效率) #### 1. **软件开发流程** - **V模型开发流程**:需求→设计→编码→单元测试→集成测试 - **配置驱动开发**:掌握ARXML文件结构与工具链交互逻辑 $$ \text{需求文档} \xrightarrow{\text{工具配置}} \text{ARXML} \xrightarrow{\text{代码生成}} \text{BSW/SWC代码} $$ #### 2. **工具链基础** - **Vector Davinci**:BSW模块配置、RTE生成 - **ETAS ISOLAR**:SWC设计与接口定义 - **调试工具**:CANoe(总线分析)、Lauterbach(MCU调试) #### 3. **汽车电子特定知识** - **ECU硬件基础**:电源管理(PMIC)、看门狗电路 - **功能安全**:ISO 26262标准中的ASIL等级划分 - **诊断协议**:UDS(Unified Diagnostic Services)服务(如$0x22$读数据)[^2] --- ### 三、学习资源推荐 1. **理论教材** - 《嵌入式实时操作系统μC/OS-II》(Jean J.Labrosse) - 《汽车CAN总线系统原理与应用》(罗峰) 2. **实践平台** - **开发板**:NXP S32K144 EVB(支持AUTOSAR MCAL) - **仿真**:CANoe Demo + Panel Designer模拟ECU交互 3. **官方文档** - AUTOSAR官网:《AUTOSAR_EXP_SoftwareArchitecture》 - ISO 26262-6:2018(功能安全部分) ```c /* 示例:AUTOSAR开发中典型的内存对齐要求 */ typedef struct { uint16_t signal_A; /* 信号A */ uint8_t signal_B; /* 信号B */ uint32_t signal_C; /* 信号C(需4字节对齐) */ } __attribute__((aligned(4))) Com_SignalGroup_t; // 显式指定4字节对齐[^1] ``` --- ### 四、能力自检清单 掌握以下内容可开始AUTOSAR学习: - [ ] 能使用C语言实现状态机控制逻辑 - [ ] 理解CAN帧结构(如ID=0x1A0, DLC=8) - [ ] 配置过MCU外设(如GPIO控制LED) - [ ] 了解RTOS任务优先级反转问题 > 注:若未满足上述基础,建议先补充嵌入式核心知识再进入AUTOSAR系[^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值