当前位置: 首页 > article >正文

别再让request.getRemoteAddr()背锅了!TongWeb7/6负载均衡后获取真实IP的两种实战方案

负载均衡环境下TongWeb获取真实客户端IP的工程实践在分布式架构盛行的今天负载均衡已成为高可用系统的标配组件。但当流量经过多层代理后后端服务获取的客户端IP往往会失真——这不仅是TongWeb特有的问题而是所有Java Web容器在负载均衡场景下都会面临的经典挑战。本文将深入剖析IP传递机制并提供两种不改一行业务代码的解决方案特别针对TongWeb6与TongWeb7的配置差异进行详细对比。1. 问题本质与常见误区当开发者调用request.getRemoteAddr()获取的IP与实际客户端不符时第一反应往往是怀疑容器或框架的bug。但事实上这是HTTP协议在代理环境下的正常现象。理解其原理才能避免陷入以下典型误区误区一归咎容器实现许多团队花费大量时间排查TongWeb源码却忽略了负载均衡器如Nginx、F5等默认不会修改TCP层源IP的特性。实际上代理服务器只是在HTTP头中添加了X-Forwarded-For等扩展字段。误区二强制修改业务代码在遗留系统中全局替换getRemoteAddr()调用可能引入兼容性风险。更优雅的方式是通过容器阀门(Valve)机制在请求进入Servlet前完成IP替换。误区三忽略日志记录一致性即使应用正确获取真实IP若访问日志仍记录代理IP会导致监控数据失真。需要在日志格式中显式声明%{X-Forwarded-For}i变量。提示X-Forwarded-For头可能包含逗号分隔的IP链如1.1.1.1, 2.2.2.2最左侧的IP才是原始客户端地址。2. 阀门(Valve)配置方案TongWeb的RemoteIpValve通过管道机制拦截请求自动将代理IP替换为X-Forwarded-For中的真实IP。不同版本配置存在差异2.1 TongWeb7配置在server.xml的对应Host标签内添加Valve classNamecom.tongweb.catalina.valves.RemoteIpValve remoteIpHeaderX-Forwarded-For protocolHeaderX-Forwarded-Proto trustedProxies192.168.1.0/24 /关键参数说明参数名必要性示例值作用className必填见上阀门实现类remoteIpHeader必填X-Forwarded-For代理IP头字段protocolHeader可选X-Forwarded-Proto协议转换(HTTP/HTTPS)trustedProxies建议10.0.0.0/8可信代理IP段2.2 TongWeb6配置TongWeb6的阀门类路径不同Valve classNamecom.tongweb.web.thor.valves.RemoteIpValve remoteIpHeaderX-Forwarded-For protocolHeaderX-Forwarded-Proto /版本差异对比特性TongWeb7TongWeb6阀门类路径catalina.valvesweb.thor.valves内网代理过滤支持trustedProxies需额外防火墙规则协议保留自动处理X-Forwarded-Proto需手动配置3. 访问日志定制方案即使阀门已正确配置默认访问日志仍记录代理IP。需修改server.xml中的日志格式3.1 扩展日志格式Valve classNamecom.tongweb.web.thor.valves.AccessLogValve pattern%{yyyy-MM-dd HH:mm:ss}t %a %{X-Forwarded-For}i %m %U %s %D /格式符号解析%a记录阀门处理后的远程IP即真实客户端IP%{X-Forwarded-For}i原始代理链IP信息%D请求处理时间毫秒3.2 安全审计建议对于需要完整代理链的场景推荐组合记录%t %a %{X-Forwarded-For}i %{User-Agent}i %m %U %s %b这将在单行日志中同时输出最终认定的客户端IP%a完整的代理路径X-Forwarded-For用户代理信息4. 高级场景与故障排查4.1 多层代理处理当流量经过CDN→WAF→负载均衡多层代理时X-Forwarded-For会形成IP链X-Forwarded-For: client, proxy1, proxy2配置阀门时需注意Valve ... internalProxies10\\..*,192\\.168\\..* remoteIpHeaderX-Forwarded-For proxiesHeaderX-Forwarded-By /4.2 常见故障排查现象一IP仍为负载均衡地址检查负载均衡器是否发送X-Forwarded-For头确认阀门配置的remoteIpHeader名称匹配现象二日志记录空IP验证日志模式是否包含%a或%{X-Forwarded-For}i检查阀门是否在日志阀门之前执行现象三出现伪造IP配置trustedProxies限制可信代理范围启用internalProxies过滤内网地址在金融级项目中我们曾遇到Nginx配置遗漏导致IP丢失的案例。最终通过tcpdump抓包确认代理层未注入关键头字段修正后的Nginx配置如下location / { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://tongweb_backend; }5. 性能优化实践阀门处理会引入额外开销在高并发场景下建议信任内网代理通过trustedProxies减少IP验证消耗精简日志字段避免记录不必要的头信息阀门执行顺序确保RemoteIpValve在其它过滤阀门之前执行实测数据显示优化后的阀门处理耗时从3ms降至0.5ms配置项平均延迟吞吐量默认配置3.2ms1200 req/s优化后0.5ms9800 req/s对于超高性能需求场景可考虑在负载均衡器如LVS直接替换源IP但这需要网络层的深度配合。

相关文章:

别再让request.getRemoteAddr()背锅了!TongWeb7/6负载均衡后获取真实IP的两种实战方案

负载均衡环境下TongWeb获取真实客户端IP的工程实践 在分布式架构盛行的今天,负载均衡已成为高可用系统的标配组件。但当流量经过多层代理后,后端服务获取的客户端IP往往会"失真"——这不仅是TongWeb特有的问题,而是所有Java Web容…...

档案数字化最后一公里难题,已被NotebookLM破解:3类高危误判场景及防御模型

更多请点击: https://intelliparadigm.com 第一章:档案数字化最后一公里难题,已被NotebookLM破解:3类高危误判场景及防御模型 档案数字化进程在OCR识别与元数据标引环节已趋成熟,但“最后一公里”——即非结构化文本语…...

【2024最新】ChatGPT联网搜索避坑白皮书:已踩过137次坑的技术总监总结出的6条铁律

更多请点击: https://intelliparadigm.com 第一章:ChatGPT联网搜索功能的核心机制与能力边界 ChatGPT 的联网搜索功能并非内置实时浏览器,而是通过插件(如 Bing Search Plugin)或企业级 API 集成方式,在用…...

FanControl完全指南:Windows风扇智能控制的终极解决方案

FanControl完全指南:Windows风扇智能控制的终极解决方案 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/…...

如何通过浏览器脚本实现网盘文件直链下载:LinkSwift 完全指南

如何通过浏览器脚本实现网盘文件直链下载:LinkSwift 完全指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘…...

手一滑,我把整个店都报上了活动

做Temu最怕什么?不是没单,不是被压价,是手滑。 去年有一次,我打算给店里十几个新款报个日常活动冲冲量。打开Temu商家后台,店铺营销,营销活动,找到合适的活动场次点了“去报名”。报名页里商品…...

安科瑞 EMS3.0智慧能源管理解决方案-光伏智维先知引擎,AI驱动预测性维护新范式

一、需求背景新能源光伏场站迈入规模化、长周期运营阶段,组件老化隐匿、故障识别滞后、运维被动响应、资产价值隐性流失已成为行业共性痛点。传统事后维修、定期检修模式难以应对复杂故障与隐性衰减,造成停机损失高、运维成本高、误判漏判率高。依托GB/T…...

别只盯着原理图:聊聊Cadence Virtuoso里带隙基准的版图匹配那些坑

带隙基准版图匹配实战:从原理图到后仿真的关键陷阱解析 当你在Cadence Virtuoso中完成了一个温漂仅2.6ppm的带隙基准电路设计,原理图仿真结果堪称完美——直到你开始画版图。这时你会发现,那些在原理图中对称排列的晶体管,在实际硅…...

保姆级教程:在HCL模拟器上给H3C路由器配置DHCP服务器(双网段实战)

从零构建H3C路由器双网段DHCP服务:模拟器实战与协议解析 在虚拟实验室中搭建网络环境已成为现代工程师的必备技能,而DHCP服务作为网络自动化的基石,其配置过程往往成为初学者接触企业级设备的第一个实战挑战。本文将使用H3C官方推出的HCL模拟…...

Lightweight Charts:高性能金融图表库的架构哲学与技术实现

Lightweight Charts:高性能金融图表库的架构哲学与技术实现 【免费下载链接】lightweight-charts Performant financial charts built with HTML5 canvas 项目地址: https://gitcode.com/gh_mirrors/li/lightweight-charts 在金融数据可视化领域,…...

从零到一:手把手部署openGauss极简版并完成基础运维

1. 环境准备:从零搭建openGauss的基石 第一次接触openGauss时,我被它"极简版"的宣传吸引,但真正动手部署才发现,前期环境准备才是决定成败的关键。就像盖房子需要打地基,数据库安装前的系统配置直接影响后续…...

从零到一:在VSCode中高效搭建PyQt5开发环境

1. 为什么选择VSCodePyQt5组合? 作为一个常年混迹Python GUI开发的老手,我尝试过各种开发环境组合,最终发现VSCodePyQt5这对搭档特别适合新手入门。PyQt5作为Qt框架的Python绑定,能让你用简单的代码创建专业级桌面应用&#xff0c…...

如何高效应用思源宋体:设计师的5个专业字体应用技巧

如何高效应用思源宋体:设计师的5个专业字体应用技巧 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文排版设计烦恼吗?思源宋体CN作为一款免费开源的专…...

CentOS8 彻底清除旧MySQL 重装 MySQL8.0

一、前言很多人安装 MySQL8 遇到:旧版本卸载不干净mysqld 启动失败找不到临时密码(无mysqld.log)密码策略报错 1819本地能连、远程无法连接本文为亲自实操、踩坑总结,命令全部可以直接复制执行,零思维负担。二、环境系…...

2024数字芯片与FPGA校招面试复盘:从项目细节到协议深挖

1. 从FPGA到数字芯片:校招面试的核心差异 去年我参加了几十场数字芯片和FPGA岗位的面试,最大的感受就是:面试官对这两类候选人的考察重点完全不同。FPGA项目出身的同学(比如我)经常会被质疑"代码量不足"、&q…...

3步终极指南:彻底解决Cursor Pro试用限制的技术实现方案

3步终极指南:彻底解决Cursor Pro试用限制的技术实现方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your t…...

通信中的拆包,残包和多线程互斥锁的注意事项。qt,c++在多线程中一定要使用全局单列互斥锁,否则肯定会崩溃,这边在读这块内存,那边要写。在网络通信中,极有可能丢包,残包,因此要做好拆包,读取,打包

使用互斥锁千万不能重复释放 mute.unlock(); mute.unlock(); 这样的写法会报错我们一定要这样使用互斥锁: // 自动锁,离开作用域自动解锁,不会拷贝锁 QMutexLocker locker(&g_CSR_Mutex);...

【紧急预警】NotebookLM在广义相对论语境下的概念漂移现象:基于57篇PRL论文的偏差审计报告

更多请点击: https://intelliparadigm.com 第一章:【紧急预警】NotebookLM在广义相对论语境下的概念漂移现象:基于57篇PRL论文的偏差审计报告 现象复现与基准测试协议 我们在标准LIGO-PRL语料集(v2.3)上对NotebookLM…...

保姆级教程:在Ubuntu 20.04上为ARM开发板(如RK3399)交叉编译Mesa图形库(含完整配置与库路径修复)

ARM开发板图形加速实战:RK3399平台Mesa交叉编译与深度优化指南 在嵌入式系统开发中,图形处理能力往往成为决定用户体验的关键因素。RK3399这类高性能ARM开发板搭载的Mali-T860 GPU,理论上能够提供出色的图形渲染性能,但要将这种潜…...

CentOS 7服务器上,从零搞定NVIDIA驱动和CUDA 11.1的保姆级避坑指南

CentOS 7服务器NVIDIA驱动与CUDA 11.1实战避坑手册 接手一台老旧GPU服务器时,最令人头疼的莫过于搭建深度学习环境。那些看似简单的安装步骤背后,往往隐藏着无数个让新手崩溃的"坑"。本文将带你穿越雷区,用最稳妥的方式在CentOS 7上…...

终极RPG Maker视差地图插件指南:零代码打造专业级游戏场景

终极RPG Maker视差地图插件指南:零代码打造专业级游戏场景 【免费下载链接】RPGMakerMV RPGツクールMV、MZで動作するプラグインです。 项目地址: https://gitcode.com/gh_mirrors/rp/RPGMakerMV 你是否曾经梦想创建拥有电影级视觉效果的RPG游戏地图&#xf…...

Termius中文版:安卓SSH客户端的完整汉化解决方案

Termius中文版:安卓SSH客户端的完整汉化解决方案 【免费下载链接】Termius-zh_CN 汉化版的Termius安卓客户端 项目地址: https://gitcode.com/alongw/Termius-zh_CN 对于需要频繁管理远程服务器的中文用户来说,英文界面的SSH客户端常常成为技术操…...

如何在5分钟内掌握BilibiliDown:B站视频下载神器完整使用指南

如何在5分钟内掌握BilibiliDown:B站视频下载神器完整使用指南 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mi…...

3步掌握VADER情感分析:颠覆传统NLP方法的实战指南

3步掌握VADER情感分析:颠覆传统NLP方法的实战指南 【免费下载链接】vaderSentiment VADER Sentiment Analysis. VADER (Valence Aware Dictionary and sEntiment Reasoner) is a lexicon and rule-based sentiment analysis tool that is specifically attuned to s…...

现代前端项目模板:从工程化配置到最佳实践全解析

1. 项目概述:一个现代前端开发的起点在接手一个新项目,特别是前端项目时,最耗时的往往不是核心业务逻辑的开发,而是那些重复性的基础搭建工作:配置构建工具、集成代码规范、设置路由和状态管理、搭建基础布局组件……每…...

Nintendo Switch大气层破解系统终极指南:从入门到精通完整教程

Nintendo Switch大气层破解系统终极指南:从入门到精通完整教程 【免费下载链接】Atmosphere-stable 大气层整合包系统稳定版 项目地址: https://gitcode.com/gh_mirrors/at/Atmosphere-stable 大气层整合包系统是为Nintendo Switch设备提供的一站式定制化固件…...

3大核心功能揭秘:如何用SMUDebugTool深度掌控AMD Ryzen处理器性能

3大核心功能揭秘:如何用SMUDebugTool深度掌控AMD Ryzen处理器性能 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址:…...

矿用防爆监控哪家更值得选择

导读:矿用防爆监控是保障煤矿等高危工业场景安全的重要设备,其性能和可靠性直接关系到生产安全。在众多品牌中,如何选择一款优质的矿用防爆监控产品成为了许多企业的关注焦点。本文将从多个维度对矿用防爆监控进行深度解析,并推荐…...

家庭Kubernetes集群实践:从硬件选型到GitOps自动化部署

1. 项目概述:从个人服务器到家庭集群的进化如果你和我一样,是个喜欢在家里折腾点技术玩意儿的爱好者,从一台树莓派跑点小服务,到后来升级成一台小主机,再到后来发现服务越来越多,备份、高可用、资源隔离这些…...

给嵌入式工程师的保姆级ISP图像调试指南:从AE曝光到3DNR降噪的完整流程

嵌入式工程师的ISP图像调试实战手册:从曝光控制到降噪优化的全链路解析 当你第一次拿到一款全新的IPC摄像头模组时,是否曾被复杂的ISP参数搞得手足无措?作为嵌入式工程师,我们往往需要在资源受限的环境中实现专业级的图像质量。本…...