内网服务器无法通过公网地址访问映射到公网的内网服务

内网服务器无法通过公网地址访问映射到公网的内网服务

    • 问题现象
    • 问题原因
    • 解决方法
    • 总结

前几天遇到一个网络问题,在这里做下记录,希望能帮助到有相同问题的朋友。

问题现象

网络拓扑示意
网络拓扑如上所示,服务器1和服务器2在同一内网,网段均为192.168.101.0/24,出口防火墙上有一个固定公网ip,地址是124.5.5.5。
服务器1上运行了一个业务系统,地址是192.168.101.111:80,然后在出口防火墙上做了映射,将其映射到了124.5.5.5:10080,此时,外部网络环境中可以正常访问124.5.5.5:10080,但是在内网环境中,如服务器2上,无法访问124.5.5.5:10080。也就是说内网服务器上无法通过映射后的公网地址访问内网服务。

问题原因

分析一下ip报文流转过程中的源目地址变化,就可以发现问题所在。
源目地址变化
服务器2访问124.5.5.5:10080时,源地址192.168.101.222目的地址124.5.5.5;
报文到达出口防火墙后,会做一次地址转换,将目的地址转换为内网地址192.168.101.111,此时源地址192.168.101.222目的地址192.168.101.111;
报文一步步到达服务器1后,服务器1做出响应,源目地址转换,此时源地址192.168.101.111目的地址192.168.101.222;
这时候,服务器1发现目的地址为同网段,报文会由服务器1通过接入交换机直接发送给服务器2;
服务器2检查报文,发现源地址是192.168.101.111,并没有与之匹配的会话(服务器2发送出去的报文目的地址是124.5.5.5),此时服务器2会丢弃这个报文,这就导致了访问不通。

解决方法

要解决这个问题,只需要使得服务器1收到的ip报文中,源地址为公网地址124.5.5.5即可,这样的话,服务器1回复的报文就变为源地址192.168.101.111目的地址124.5.5.5,报文会经过防火墙后再回到服务器2,完成整个通信过程。
要实现以上操作,只需要在防火墙上配置一条源NAT,将源目网段192.168.101.0/24的报文,源地址转换为124.5.5.5,并将该条SNAT应用到防火墙与核心交换机相连的那个接口上。

总结

做完以上配置后,服务器2(192.168.101.222)通过124.5.5.5:10800访问服务器1(192.168.101.111:80)时,网络流量的流转及地址变化如下:

1.数据包从S2发出
源地址:192.168.101.222:随机端口(假设为54321)
目的地址:124.5.5.5:10800
路径:S2 → 接入交换机 → 汇聚交换机→ 核心交换机 → 防火墙(内网接口)

2.防火墙处理(入口方向)
a.目的NAT(DNAT)
规则:将 124.5.5.5:10800映射到192.168.101.111:80
转换后数据包:
源地址:192.168.101.222:54321
目的地址:192.168.101.111:80
b. 源NAT(SNAT)
规则:源目均为192.168.101.0/24的流量,源地址转换为124.5.5.5
转换后数据包:
源地址:124.5.5.5:54321(端口可能保持不变或变化)
目的地址:192.168.101.111:80
路径:防火墙 → 核心交换机→ 汇聚交换机 → 接入交换机 → S1

3.S1 处理请求并响应
接收的数据包:
源地址:124.5.5.5:54321
目的地址:192.168.101.111:80
响应数据包:
源地址:192.168.101.111:80
目的地址:124.5.5.5:54321
路径:S1 → 接入交换机 → 汇聚交换机→ 核心交换机 → 防火墙(内网接口)

4.防火墙处理(出口方向)
反向NAT(基于连接跟踪):
反向DNAT:将目的地址124.5.5.5:54321还原为192.168.101.222:54321
反向SNAT:将源地址192.168.101.111:80还原为124.5.5.5:10800
转换后响应包:
源地址:124.5.5.5:10800
目的地址:192.168.101.222:54321
路径:防火墙 → 核心交换机 → 汇聚交换机 → 接入交换机 → S2

5.S2 接收响应
最终数据包:
源地址:124.5.5.5:10800
目的地址:192.168.101.222:54321
S2 视角:认为与124.5.5.5:10800通信成功,整个过程透明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42609.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mac 下配置flutter 总是失败,请参考文章重新配置flutter 环境MacOS Flutter环境配置和安装

一、安装和运行Flutter的系统环境要求 想要安装并运行 Flutter,你的开发环境需要最低满足以下要求: 操作系统:macOS磁盘空间:2.8 GB(不包括IDE/tools的磁盘空间)。工具:Flutter使用git进行安装和升级。我们建议安装Xcode,其中包括git&#x…

Linux的进程信号 -- 信号产生,信号保存,信号捕捉,硬件中断,内核态和用户态,可重入函数,volatile,SIGCHLD

目录 1. 认识信号 1.1 信号的定义和基本结论 1.1.1 查看信号 1.2 技术应用角度的信号 1.2.1 一个样例 1.2.2 系统调用 signal 函数 1.3 信号的处理 2. 信号的产生 2.1 通过终端按键产生信号 2.1.1 基本操作 2.1.2 理解操作系统如何得知键盘信号 2.1.3 初步理解信号…

知识库中嵌入模型(Embedding Models)与重排序模型(Re-ranking Models)推荐工具与库

一、引言 在当今信息爆炸的时代,企业和组织面对海量数据时,如何快速、准确地检索和利用知识成为一项关键技术。知识库作为信息管理和知识发现的核心平台,已经广泛应用于搜索引擎、问答系统、智能客服、推荐系统等领域。然而,传统…

C++调用Python

Python安装 地址: python官网 可以根据需要下载对应的版本。 调用python python测试脚本 # my_script.py import sys import jsondef calculate(a, b):return a * b 10 # 示例计算逻辑if __name__ "__main__":# 从命令行参数读取 JSON 字符串try…

Linux 中查看文件大小方法

目录 方法一:ls -l 输出的第五列方法二:du 命令的输出信息方法三:stat -c %s 的输出 方法一:ls -l 输出的第五列 ls 是列出指定目录下文件列表的命令,通过 -l 选项可以显示文件的属性信息,第五列显示的就是…

初识Qt(一)

本文部分ppt、视频截图原链接:萌马工作室的个人空间-萌马工作室个人主页-哔哩哔哩视频 1. Qt是什么? Qt是一个跨平台的C应用程序开发框架,它既为图形用户界面(GUI)程序开发提供了强大支持,也能用于开发非GUI的控制台程序、服务端…

docker - compose up - d`命令解释,重复运行会覆盖原有容器吗

docker - compose up - d`命令解释,重复运行会覆盖原有容器吗 docker - compose up - d 是一个用于管理 Docker 容器的命令,具体含义如下: 命令含义: up:用于创建、启动并运行容器,会根据 docker - compose.yml 文件中定义的服务配置来操作。-d:表示以“分离模式”(det…

《2核2G阿里云神操作!Ubuntu+Ollama低成本部署Deepseek模型实战》

简介: “本文为AI开发者揭秘如何在阿里云2核2G轻量级ECS服务器上,通过Ubuntu系统与Ollama框架实现Deepseek模型的高效部署。无需昂贵硬件,手把手教程涵盖环境配置、资源优化及避坑指南,助力初学者用极低成本在云端跑通行业领先的大…

DexGrasp Anything:具有物理-觉察的普遍机器人灵巧抓取

25年3月来自上海科技大学的论文“DexGrasp Anything: Towards Universal Robotic Dexterous Grasping with Physics Awareness”。 能够抓取任何物体的灵巧手,对于通用具身智能机器人的开发至关重要。然而,由于灵巧手的自由度高,物体种类繁多…

COMPASS:通过残差强化学习和技能合成实现跨具身移动策略

25年2月来自 Nvidia、UC Berkeley 和 UT Austin 的论文“COMPASS: Cross-embOdiment Mobility Policy via ResiduAl RL and Skill Synthesis”。 随着机器人越来越多地部署在不同的应用领域,可泛化的跨具身移动策略变得越来越重要。虽然经典的移动栈已被证明在特定…

win10下python脚本运行缺失ccache的问题处理

问题 python脚本运行时,会提醒参考 https://github.com/ccache/ccache/blob/master/doc/INSTALL.md 处理缺失ccache的问题。 下载编译 下载ccache主干版本, 例如 https://github.com/ccache/ccache/archive/refs/heads/master.zip 按照说明编译 mkd…

跨语言语言模型预训练

摘要 最近的研究表明,生成式预训练在英语自然语言理解任务中表现出较高的效率。在本研究中,我们将这一方法扩展到多种语言,并展示跨语言预训练的有效性。我们提出了两种学习跨语言语言模型(XLM)的方法:一种…

3月28号

今天写了一些算法题: P1866 编号 题目描述 太郎有 N 只兔子,现在为了方便识别它们,太郎要给他们编号。兔子们向太郎表达了它们对号码的喜好,每个兔子 i 想要一个整数,介于 1 和 Mi​ 之间(可以为 1 或 Mi​&#xf…

数据结构与算法:2,冒泡排序

以从小到大排序为例: 冒泡排序步骤: 1,从左到右(或从右到左)对比相邻两个数,左边的数 大于 右边的数 则交换位置 2,重复第一个步骤 ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​…

从春招“AI热潮”看科技变革中的就业新趋势

随着2025年春招市场的火热进行,人工智能(AI)相关岗位成为求职市场上的“香饽饽”,引发了社会各界的广泛关注。这一现象背后,不仅反映了AI技术的快速发展,更揭示了科技变革对就业市场带来的深远影响。从春招…

人工智能之数学基础:矩阵的相似变换

本文重点 矩阵的相似变换是线性代数中一个至关重要的概念,它揭示了矩阵之间的一种特殊关系,并通过可逆矩阵将一个矩阵转化为另一个相似矩阵,同时保持矩阵的某些本质特征不变。在机器学习领域,矩阵的相似变换发挥着不可或缺的作用,广泛应用于数据降维、聚类分析、分类推荐…

docker torcherve打包mar包并部署模型

使用Docker打包深度网络模型mar包到服务端 参考链接:Docker torchserve 部署模型流程——以WSL部署YOLO-FaceV2为例_class myhandler(basehandler): def initialize(self,-CSDN博客 1、docker拉取环境镜像命令 docker images出现此提示为没有权限取执行命令&…

JAVA实现动态IP黑名单过滤

一些恶意用户(可能是黑客、爬虫、DDoS 攻击者)可能频繁请求服务器资源,导致资源占用过高。因此需要一定的手段实时阻止可疑或恶意的用户,减少攻击风险。 通过 IP 封禁,可以有效拉黑攻击者,防止资源被滥用,保障合法用户…

RocketMQ可视化工具使用 - Dashboard(保姆级教程)

1、github拉取代码,地址: https://github.com/apache/rocketmq-dashboard 2、指定Program arguments,本地启动工程 勾上这个Program arguments,会出现多一个对应的框 写入参数 --server.port1280 --rocketmq.config.namesrvAddr…

湖南(源点咨询)市场调研 商业综合体定位调研分享(上篇)

​ 该项目位于某新一线城市的城市副中心区域,系一个正在发展中的中央居住区,项目本身是一个涵盖社区综合服务中心、商业、文体活动中心、卫生服务、社区养老等多功能复合的公共配套项目,本次调研主要针对其商业(及其他可商用的&a…