TT Bigdata TT Bigdata
首页
  • 部署专题

    • 常规安装
    • 一键部署
  • 组件专题

    • 安装指导
    • 实战 Kerberos
    • 魔改分享
  • 版本专题

    • 更新说明
    • BUG临时处理
  • 实验室

    • VIEW插件
    • JIRA速查
  • Ambari-Env

    • 环境准备
    • 开始使用
  • 组件编译

    • 专区—Ambari
    • 专区—Bigtop-官方组件
    • 专区—Bigtop-扩展组件
  • 报错解决

    • 专区—Ambari
    • 专区—Bigtop
  • 其他技巧

    • APT仓库增量更新
    • Maven镜像加速
    • Gradle镜像加速
    • Bower镜像加速
    • 虚拟环境思路
    • R环境安装+一键安装脚本
    • Ivy配置私有镜像仓库
    • Node.js 多版本共存方案
    • Ambari Web本地启动
    • Npm镜像加速
    • PostgreSQL快速安装
    • Temurin JDK 23快速安装
  • 成神之路

    • 专区—Ambari
    • 专区—Ambari-Metrics
    • 专区—Bigtop
  • 集成案例

    • Redis集成教学
    • Dolphin集成教学
    • Doris集成教学
    • 持续整理...
  • 核心代码

    • 各组件代码
    • 通用代码模板
  • 国产化&其他系统

    • Kylin V10系列
    • Rocky系列
    • Ubuntu系列
  • Grafana监控方案

    • Ambari-Metrics插件
    • Infinity插件
  • 支持&共建

    • 蓝图愿景
    • 合作共建
登陆
GitHub (opens new window)

JaneTTR

数据酿造智慧,每一滴都是沉淀!
首页
  • 部署专题

    • 常规安装
    • 一键部署
  • 组件专题

    • 安装指导
    • 实战 Kerberos
    • 魔改分享
  • 版本专题

    • 更新说明
    • BUG临时处理
  • 实验室

    • VIEW插件
    • JIRA速查
  • Ambari-Env

    • 环境准备
    • 开始使用
  • 组件编译

    • 专区—Ambari
    • 专区—Bigtop-官方组件
    • 专区—Bigtop-扩展组件
  • 报错解决

    • 专区—Ambari
    • 专区—Bigtop
  • 其他技巧

    • APT仓库增量更新
    • Maven镜像加速
    • Gradle镜像加速
    • Bower镜像加速
    • 虚拟环境思路
    • R环境安装+一键安装脚本
    • Ivy配置私有镜像仓库
    • Node.js 多版本共存方案
    • Ambari Web本地启动
    • Npm镜像加速
    • PostgreSQL快速安装
    • Temurin JDK 23快速安装
  • 成神之路

    • 专区—Ambari
    • 专区—Ambari-Metrics
    • 专区—Bigtop
  • 集成案例

    • Redis集成教学
    • Dolphin集成教学
    • Doris集成教学
    • 持续整理...
  • 核心代码

    • 各组件代码
    • 通用代码模板
  • 国产化&其他系统

    • Kylin V10系列
    • Rocky系列
    • Ubuntu系列
  • Grafana监控方案

    • Ambari-Metrics插件
    • Infinity插件
  • 支持&共建

    • 蓝图愿景
    • 合作共建
登陆
GitHub (opens new window)
  • Hadoop

  • Spark

  • Trino

  • Hudi

  • Paimon

  • Livy

  • Flink

  • Atlas

  • Superset

  • Jsvc

  • Zookeeper

  • Hive

  • Sqoop

  • Cloudbeaver

  • Bigtop-select

  • Knox

    • xmlsectool 依赖缺失问题解析
    • webhdfs-test 依赖收敛冲突问题处理
    • Invalid keystore format 问题处理
    • Knox is not allowed to impersonate admin
    • X-Forwarded-For 406 错误的原因与处理
      • 一、问题现象:Knox 转发访问 Trino Web UI 返回 406
      • 二、问题根因:Trino 默认拒绝 Forwarded 请求头
      • 三、Ttbigdata 发行版的处理方式(推荐)
        • 3.1 配置项说明
        • 3.2 在 Ambari / 管理界面中开启
        • 3.3 验证结果
      • 四、非 Ttbigdata 发行版的处理方式
        • 4.1 修改 config.properties.j2 模板
        • 4.2 在 config.properties.xml 中声明配置项
        • 4.3 文件下发与生效
  • Hue

  • 报错解决-Bigtop
  • Knox
JaneTTR
2025-12-24
目录

X-Forwarded-For 406 错误的原因与处理

# 一、问题现象:Knox 转发访问 Trino Web UI 返回 406

在 Knox 已完成接入、并通过 Knox 访问 Trino Web UI 时,点击页面链接后直接返回 406 错误:

对应的访问地址示例如下:

https://dev1:28443/ui/login.html?doAs=admin
1

浏览器返回的完整错误信息为:

HTTP ERROR 406 Server configuration does not allow processing of the X-Forwarded-For header
URI:	https://dev1:28443/ui/login.html?doAs=admin
STATUS:	406
MESSAGE:	Server configuration does not allow processing of the X-Forwarded-For header
Caused by:
org.eclipse.jetty.http.BadMessageException: 406: Server configuration does not allow processing of the X-Forwarded-For header
	at io.airlift.http.server.RejectForwardedRequestCustomizer.customize(RejectForwardedRequestCustomizer.java:20)
	at org.eclipse.jetty.server.internal.HttpChannelState$HandlerInvoker.run(HttpChannelState.java:655)
	at org.eclipse.jetty.server.internal.HttpConnection.onFillable(HttpConnection.java:416)
	at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:322)
	at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:99)
	at org.eclipse.jetty.io.ssl.SslConnection$SslEndPoint.onFillable(SslConnection.java:575)
	at org.eclipse.jetty.io.ssl.SslConnection.onFillable(SslConnection.java:390)
	at org.eclipse.jetty.io.ssl.SslConnection$2.succeeded(SslConnection.java:150)
	at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:99)
	at org.eclipse.jetty.io.SelectableChannelEndPoint$1.run(SelectableChannelEndPoint.java:53)
	at org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.runTask(AdaptiveExecutionStrategy.java:480)
	at org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.consumeTask(AdaptiveExecutionStrategy.java:443)
	at org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.tryProduce(AdaptiveExecutionStrategy.java:293)
	at org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.run(AdaptiveExecutionStrategy.java:201)
	at org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:311)
	at org.eclipse.jetty.util.thread.MonitoredQueuedThreadPool$1.run(MonitoredQueuedThreadPool.java:73)
	at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:979)
	at org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.doRunJob(QueuedThreadPool.java:1209)
	at org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:1164)
	at java.base/java.lang.Thread.run(Thread.java:1575)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

后端 Jetty 日志中可看到如下异常堆栈(节选):

org.eclipse.jetty.http.BadMessageException: 406:
Server configuration does not allow processing of the X-Forwarded-For header
	at io.airlift.http.server.RejectForwardedRequestCustomizer.customize
1
2
3

现象特征

  • Knox 本身工作正常
  • Trino 进程未崩溃
  • 请求在 Trino Jetty 层被直接拒绝
  • 错误与 X-Forwarded-For 请求头强相关

# 二、问题根因:Trino 默认拒绝 Forwarded 请求头

Knox 在转发 Web UI 请求时,会自动附加标准代理请求头,包括:

  • X-Forwarded-For
  • X-Forwarded-Proto
  • X-Forwarded-Host

这是反向代理场景的标准行为。

而 Trino 的 Web UI 是基于 Jetty(Airlift HTTP Server)实现的, 其默认安全策略是:

如果未显式开启 forwarded header 处理,则拒绝包含 X-Forwarded- 的请求*

因此在默认配置下,Trino 会在 Jetty 层直接抛出:

RejectForwardedRequestCustomizer
1

并返回 HTTP 406。

结论

这不是 Knox 的问题,也不是认证问题, 而是 Trino 未开启 forwarded header 支持。

# 三、Ttbigdata 发行版的处理方式(推荐)

在 Ttbigdata 发行版 中,该参数已经被纳入 Trino 的可配置项,只需开启即可。

# 3.1 配置项说明

需要启用的配置为:

http-server.process-forwarded
1

其含义是:

允许 Trino 处理来自反向代理(如 Knox)的 X-Forwarded-* 请求头

# 3.2 在 Ambari / 管理界面中开启

在 Trino 的配置栏目中,找到对应配置项并设置为 true:

配置完成后:

  1. 保存配置
  2. 重启 Trino 服务

# 3.3 验证结果

重启完成后,再次通过 Knox 访问 Trino Web UI:

页面可以正常加载,406 错误消失。

# 四、非 Ttbigdata 发行版的处理方式

如果使用的不是 Ttbigdata 发行版,需要从 模板与配置文件层面补齐该参数。

# 4.1 修改 config.properties.j2 模板

在 Trino 的 config.properties.j2 模板中追加如下内容:

新增配置:

http-server.process-forwarded={{ config_properties['http-server.process-forwarded'] }}
1

# 4.2 在 config.properties.xml 中声明配置项

同时,需要在 config.properties.xml 中补齐该配置定义:

用于让 Ambari / 配置系统能够感知并下发该参数。

# 4.3 文件下发与生效

上述两个文件:

  • config.properties.j2
  • config.properties.xml

需要放置到对应的 Trino 配置模板目录中, 具体路径与发布方式在其它章节已有详细说明,此处不再展开。

完成配置后,重启 Trino 服务即可生效。

#Bigtop#Knox#Trino#Web UI#X-Forwarded-For#Jetty#运维排错
Knox is not allowed to impersonate admin
Hue 访问 Hadoop 权限问题

← Knox is not allowed to impersonate admin Hue 访问 Hadoop 权限问题→

最近更新
01
xmlsectool 依赖缺失问题解析
12-24
02
webhdfs-test 依赖收敛冲突问题处理
12-24
03
Invalid keystore format 问题处理
12-24
更多文章>
Theme by Vdoing | Copyright © 2017-2025 JaneTTR | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式