【Knox编译】xmlsectool 依赖缺失问题解析

一、问题背景

代码已经提交到github,完整代码请参考:Ttbigdata

在基于 Bigtop 编译 Apache Knox 2.1.0 的过程中,整体构建已经进入后半段,大量模块显示为 SKIPPED,但在处理安全相关模块时构建突然中断。

从构建路径和模块名称可以判断,此阶段已经进入 Knox 的 Provider / Security 相关实现,一旦失败,后续 Knox 组件将全部无法继续。

这类问题在 Bigtop + 内网 Nexus 的环境下非常常见,

并不属于代码问题,而是典型的 第三方 Maven 依赖缺失

二、报错信息与日志定位

核心报错信息如下:

bash 复制代码
NFO] gateway-service-session 2.1.0 ...................... SKIPPED
[INFO] gateway-release 2.1.0 .............................. SKIPPED
[INFO] gateway-service-vault 2.1.0 ........................ SKIPPED
[INFO] gateway-test-release-utils 2.1.0 ................... SKIPPED
[INFO] gateway-test 2.1.0 ................................. SKIPPED
[INFO] gateway-test-release 2.1.0 ......................... SKIPPED
[INFO] webhdfs-kerb-test 2.1.0 ............................ SKIPPED
[INFO] webhdfs-test 2.1.0 ................................. SKIPPED
[INFO] gateway-shell-release 2.1.0 ........................ SKIPPED
[INFO] gateway-docker 2.1.0 ............................... SKIPPED
[INFO] gateway-release-common 2.1.0 ....................... SKIPPED
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  12:13 min
[INFO] Finished at: 2025-12-11T02:52:38Z
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal on project gateway-provider-security-pac4j: Could not resolve dependencies for project org.apache.knox:gateway-provider-security-pac4j:jar:2.1.0: Could not find artifact net.shibboleth.tool:xmlsectool:jar:2.0.0 in nexus (http://172.20.0.2:8081/repository/maven-public/) -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/DependencyResolutionException
[ERROR]
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR]   mvn <args> -rf :gateway-provider-security-pac4j
(base) [root@kylin10 knox-2.1.0-RC2]#

同时可以看到构建最终状态:

bash 复制代码
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  12:13 min
[INFO] Finished at: 2025-12-11T02:52:38Z

从日志中可以提取几个关键信息点:

项目 内容
失败模块 gateway-provider-security-pac4j
缺失依赖 net.shibboleth.tool:xmlsectool:2.0.0
Maven 仓库 内部 Nexus(maven-public)
错误类型 DependencyResolutionException

三、问题根因分析

1. xmlsectool 并不在 Maven Central

xmlsectool 属于 Shibboleth 项目体系,其官方 Maven 仓库地址为:

text 复制代码
https://build.shibboleth.net/maven/releases/

该依赖 默认不发布在 Maven Central,因此:

  • 本地 Maven
  • 企业 Nexus
  • Bigtop 默认构建链路

都无法自动拉取该依赖

2. 内部 Nexus 未代理 Shibboleth 仓库

当前构建使用的仓库为:

text 复制代码
http://172.20.0.2:8081/repository/maven-public/

如果该 group 中未包含 shibboleth-releases,那么 Maven 在解析依赖时必然失败。

这个问题 和 Knox 版本无关和 Bigtop 无关

本质是 仓库覆盖不完整

四、解决方案

针对 xmlsectool 依赖缺失的问题,本质上只有一个目标:

让 Maven 能解析到 net.shibboleth.tool:xmlsectool:2.0.0

根据环境不同,可以采用两种方式。

方案一:通过 Nexus 统一托管 xmlsectool 依赖(推荐)

该方案适用于:

  • 企业内网
  • 多人协作
  • 多次重复编译 Bigtop / Ambari / Knox
1. 添加 Shibboleth Releases 仓库

在 Nexus 中新增一个 Maven Proxy Repository

  • Name:shibboleth-releases
  • Remote URL:
text 复制代码
https://build.shibboleth.net/maven/releases/
2. 加入 maven-public Group

shibboleth-releases 添加到 maven-public 组仓库中,确保构建时可以被统一解析。

3. 恢复构建
bash 复制代码
mvn compile -rf :gateway-provider-security-pac4j

-rf(resume from)是 Bigtop / Knox 编译中非常常用的参数,

可以避免从头全量重编。

4. 一键脚本方式(推荐)

如果不想手工配置 Nexus,可以直接使用我们整理的一键脚本:

bash 复制代码
https://github.com/TtBigdata/ambari-env/blob/master/scripts/system/after/nexus/setup_mvn_proxy.sh

该脚本会自动补齐:

  • Shibboleth
  • Apache Snapshots
  • 其他常见第三方 Maven 仓库

方案二:直接下载并安装到本地 Maven 仓库

该方案适用于:

  • 无法修改 Nexus
  • 临时编译
  • 单机调试环境
1. 下载 xmlsectool 依赖

官方目录地址:

text 复制代码
https://build.shibboleth.net/maven/releases/net/shibboleth/tool/xmlsectool/
2. 安装到本地仓库
bash 复制代码
mvn install:install-file \
  -DgroupId=net.shibboleth.tool \
  -DartifactId=xmlsectool \
  -Dversion=2.0.0 \
  -Dpackaging=jar \
  -Dfile=xmlsectool-2.0.0.jar
相关推荐
yumgpkpm1 天前
在AI语言大模型时代 Cloudera CDP(华为CMP 鲲鹏版)对自有知识的保护
人工智能·hadoop·华为·zookeeper·spark·kafka
沃达德软件1 天前
巡防勤务可视化管理
大数据·人工智能·数据挖掘·数据分析
zhangxl-jc1 天前
Hive基本操作日记
数据仓库·hive·hadoop
永霖光电_UVLED1 天前
连续波 UV-B 激光二极管问世,实现全球首次
大数据·人工智能·uv
CHrisFC1 天前
江苏硕晟 LIMS 系统:加速环境检测机构合规化进程的利器
大数据·人工智能
智能相对论1 天前
Hilight开启公测:营销视频的“DeepSeek时刻”,来了
大数据·人工智能·音视频
计算机毕业编程指导师1 天前
【Python大数据选题】基于Hadoop+Spark奥运会金牌榜可视化分析系统源码 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘
大数据·hadoop·python·计算机·spark·毕业设计·奥运会金牌
袋鼠云数栈1 天前
袋鼠云产品功能更新报告(第16期)|离线开发新进化:AI辅助与架构升级
大数据·人工智能·架构
TTBIGDATA1 天前
【Hue】Hue 访问 Hadoop 权限问题出现 403 的解决办法
大数据·hadoop·分布式·ambari·hdp·hue·bigtop
【赫兹威客】浩哥1 天前
【赫兹威客】伪分布式ZooKeeper测试教程
大数据·分布式·zookeeper