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

NAT/代理服务器/内网穿透

目录

一 NAT技术

二 内网穿透/内网打洞

三 代理服务器


一 NAT技术

跨网络传输的时候,私网不能直接访问公网,就引入了NAT能讲私网转换为公网进行访问,主要解决IPv4(2^32)地址不足的问题。

1. NAT原理

当某个内网想访问公网,就必须先找到处于同一个网段的出入口路由器,而内网又不能暴露在公网上,所以当IP地址到达路由器时,路由器会把源IP转换成路由器的WAN口IP,并和源IP进行映射,这里他们互为 key <=> val,当服务器回显时,填充目的服务器IP地址,也就是之前经过转换后的IP地址,源地址填服务器的IP地址,在路由到目的IP所在的路由器,并由该路由器进行查映射表,查到转换之前的私有IP,在进行转发。

示例:

假设路由器的IP地址是202.244.174.37,源主机IP为10.0.0.10,目的IP地址为163.221.120.9

1. 经过路由器转换进行映射:

源:    10.0.0.10 <=> 路由器:202.244.174.37

目的:163.221.120.9 <=> 路由器:163.221.120.9

2. 经过服务器响应并路由回来:

服务器填充源IP:163.221.120.9,目的IP:202.244.174.37

路由器进行查表:202.244.174.37,查到得到:10.0.0.10,并交付给最初的主机。

3. 如果有2台主机同时向同一个目标服务器,那么路由器进行替换的时候就是:

源:    10.0.0.10 <=> 路由器:202.244.174.37

源:    10.0.0.11 <=> 路由器:202.244.174.37

这时就有2对一样的key了,后面的key会把前面的key覆盖掉,导致一方的主机的请求响应给后一个主机了,针对这个问题,路由器不仅要保存IP地址还要保存端口号,并让后来的端口号++,这样后续响应回来的数据虽然IP地址重复了,但端口号不一样,也就解决了多台主机访问同一资源映射导致的问题了,所以路由器不仅要缓存IP地址也要缓存端口号。

4. 这种把源IP地址/端口进行替换并建立映射就是NAT技术。

二 内网穿透/内网打洞

1. 前置

1. 正常主机A访问服务器进行一系列的NAT转换最终得到响应。

2. 那么一开始映射表没有服务器能不能直接访问主机A,不能,私网不能出现在公网上,同样的不同子网的内网最开始也不能直接通信。

2. 内网穿透

当B访问B自己的服务器建立映射表,并且服务器将来把收到的报文在转发到B自己,此时A访问这个服务器,服务器就会把A的报文转发到B,之前已经建立了B到服务器的映射,现象就是A直接穿透到了B,也就是内网穿透。

2. 内网穿透

这种通过得到对方转换后的IP地址,并且对方已经建立了映射表,后续就可以不通过公网服务器,直接路由到对方的路由器,因为对方已经和路由器建立了映射,发送方拿映射后的IP地址就能直接访问到对方建立映射表的路由器,这种不通过公网,直接从一个路由器跳到另一个路由器的技术也就是内网打洞,类似对方的路由器打了个洞,让发送方直接进去。

三 代理服务器

1. 正向代理

多个主机访问外网首先会经过代理服务器,由该服务器部署的某些服务帮你访问并响应回去,为什么要这么做?统一管理这些主机,比如访问非法网站,陌生的IP地址就直接不做转发,请求也就失败了。如果有多台主机访问同一个静态资源,代理服务器也能缓存,收到请求直接返回提高效率。当进行转发的时候把主机的IP替换成代理服务器的IP地址,也能保护主机的身份。某个主机资源开销高,就限制这台主机的资源速率,比如控制下载速度等。

2. 反向代理

发送方主机请求打到代理服务器,由代理服务去分配给接收方主机,比如采用轮询,随机分配等策略,避免某一台主机压力爆满,而其他的一直空闲,这种技术叫做负载均衡,当然也能保护客户端的身份,缓存等。

相关文章:

  • SpringBoot整合MQTT实战:基于EMQX构建高可靠物联网通信,从零到一实现设备云端双向对话
  • K8S Ingress 实现金丝雀(灰度)发布
  • NVMe简介1
  • FFMPEG 与 mp4
  • FunASR:语音识别与合成一体化,企业级开发实战详解
  • Turborepo + Vite + Next.js + Shadcn Monorepo 项目构建
  • MoonBit正式入驻GitCode!AI时代的编程语言新星,开启高性能开发新纪元
  • 【面试 · 五】CSS个别重点总结
  • 【内网渗透】——S4u2扩展协议提权以及KDC欺骗提权
  • Xcode报错:“Set `maskView` to `nil` before adding it as a subview of ZFMaskView
  • 嵌入式培训之数据结构学习(三)gdb调试
  • 深入解析京东 item_sku 接口:获取商品SKU信息的详细指南
  • libarchive.so.19丢失
  • 使用libUSB-win32的简单读写例程参考
  • 基于SpringBoot+Vue的房屋租赁管理系统源码包(完整版)开发实战
  • 现代垃圾收集器
  • 【springcloud学习(dalston.sr1)】Ribbon负载均衡(七)
  • svn status . 命令返回分析
  • npm 报错 gyp verb `which` failed Error: not found: python2 解决方案
  • 2025年Flutter项目管理技能要求
  • 商务部新闻发言人就出口管制管控名单答记者问
  • 李家超:明日起香港特区护照持有人可免签入境阿联酋
  • 网约车座椅靠背张贴“差评者得癌症”,如祺出行:未收到投诉无法处理
  • 日本前卫艺术先驱群展上海:当具体派相遇古树古宅
  • “11+2”复式票,宝山购彩者领走大乐透1170万头奖
  • 通化市委书记孙简升任吉林省副省长