tnblog
首页
视频
资源
登录

网络 SNAT与DNAT

6268人阅读 2022/5/15 18:35 总访问:3475892 评论:0 收藏:0 手机
分类: 容器编排

Kubernetes

网络 SNAT与DNAT

NAT简介


网络地址转换NAT(Network Address Translation)是将IP数据报文中的IP地址转换为另一个IP地址的过程。
随着internet的发展和网络应用的增多,IPV4地址枯竭已成为制约网络发展的瓶颈。尽管IPV6可以从根本上解决IPv4地址空间不足的问题,但目前众多网络设备和网络应用大多数是基于IPv4的,因此在IPv6广泛应用之前,一些过滤技术(如CIDR、私网地址等)的使用是解决这个问题最主要的技术手段。NAT主要用于实现内部网络(简称内网,使用私有的网络地址)访问外部网络(简称外网,使用公有IP地址)的功能。当内网的主机要访问外网时,通过NAT技术可以将其私网地址转换为公网地址,可以实现多个私网用户共用一个公网地址来访问外部网络。

优点 缺点
节省IP地址空间 增加转发延迟
解决IP地址重叠问题 丧失端到端的寻址能力
增加网络连入internet的弹性 某些应用不支持NAT
网络变更的时候减少IP重编址带来的麻烦 需要一定的内存空间支持动态存储NAT表项
对外隐藏内部地址,增加网络安全性 需要耗费一定NAT资源进行操作,需耗费一定内存资源进行存储NAT表项

静态NAT(SNAT)


Static NAT,静态NAT,用于将内部本地地址(私有IP)与内部全局地址(公有IP)进行一对一的映射。缺点是需要每一个内部IP地址需独占一个宝贵的公网地址。即,如果某个合法IP地址已经被NAT静态的IP地址转换定义,即使该地址当前没有被使用,也不能被用作其他的地址转换。而且这种方式是静态手工创建的NAT映射,可扩展性不高。

这种方法主要用在内网中存在需要对公网提供服务的服务器场景,类似的场景有Web服务器、邮件服务器、FTP服务器等。

Static NAT支持IP对IP的映射,以及端口对端口的映射。


我们可以看到在私网访问外网时,仅仅是对发送端的IP进行了修改,那MAC有没有修改呢?这里我们保留一个疑问,在接下来我们将通过ENSP来进行实践。

通过ENSP模拟IP对IP


我们需要实践的如下图所示:


PC1的IP是192.168.0.2/24,AR1上的网关为192.168.0.1/24
Server1的IP为2.2.2.1/24,AR1上的网关为2.2.2.2/24下面是相关配置图。


我们知道SNAT是需要一对一的映射IP,所以我们只需要在PC1发往Server1数据包在AR1中的192.168.0.2设置为2.2.2.3/24之后再进行转发就可以进行与Server的通信了。命令如下:

  1. system-view
  2. # 查看当前AR1配置
  3. dis current-configuration
  4. # 重命名为Router
  5. sysname Router
  6. # 为0/0/0接口添加网关
  7. interface GigabitEthernet0/0/0
  8. ip address 192.168.0.1 255.255.255.0
  9. # 为0/0/1接口添加网关
  10. interface GigabitEthernet0/0/1
  11. ip address 2.2.2.2 255.255.255.0
  12. # 将PC1的IP映射为2.2.2.3
  13. nat static global 2.2.2.3 inside 192.168.0.2 netmask 255.255.255.255
  14. # 设置所有到该路由的流量下一站为2.2.2.1
  15. ip route-static 0.0.0.0 0.0.0.0 2.2.2.1


运行测试。

  1. ping 2.2.2.1


接下来我们分析GE0/0/1的包,发现它是从2.2.2.3发过来的。
GE0/0/0不用说了把是从192.168.0.2发到路由来的。
我们发现发送端的IP与MAC都变了,但MAC是哪个接口的MAC呢?


我们通过dis arp查看IP所对应的MAC,发现MAC是2.2.2.2的。


然后我们添加一个PC2,由于没有配置SNAT,没有对应的IP映射,所以导致私网无法请求服务器端,我们可以看到后面的抓0/0/1接口的包也是没有想关请求的。

SNAT Easy IP


Easy IP 特别适合小型局域网访问Internet的情况。这里的小型局域网主要指中小型网吧、小型办公室等环境,一般据有以下特点:内部主机较少、出接口通过拨号方式获得临时公网IP地址以供内部主机访问Internet。对于这种情况,可以使用Easy IP 方式使局域网用户都可以通过这个IP地址接入Internet。
对于只申请到少量IP地址甚至只有一个合法IP地址却经常有很多用户要求同时上网的情况,这种转换方式非常有用。这种地址转换方式真正意义上缓解了IPv4地址紧缺的问题。在各种网络中被广泛使用。

Linux下实现SNAT


我们知道内部地址要访问公网上的服务时,内部地址会主动发起连接,将内部地址转换成公有ip。网关这个地址转换称为 SNAT。但在Linux下我们应该如何模拟呢?我们可以通过下面的拓扑图进行实践。

  1. # 添加br0
  2. ip netns add ns1
  3. ip l a br0 type bridge
  4. ip l s br0 up
  5. # 配置br0和veth0
  6. ip l a veth0 type veth peer name br-veth0
  7. ip l s veth0 netns ns1
  8. ip l s br-veth0 master br0
  9. ip l s br-veth0 up
  10. # 配置ns1中的接口
  11. ip netns exec ns1 ip a a 10.1.1.2/24 dev veth0
  12. ip netns exec ns1 ip l s veth0 up
  13. ip a a 10.1.1.1/24 dev br0
  14. ip l s br0 up
  15. ip netns exec ns1 ifconfig lo up
  16. # 添加路由
  17. ip netns exec ns1 route add -net 0.0.0.0 gw 10.1.1.1
  18. # 修改内核转发
  19. echo 1 > /proc/sys/net/ipv4/ip_forward
  20. # 添加SNAT规则
  21. # 假设让iptables防火墙承担NAT服务器功能。此时,如果希望内网10.1.1.0/24出去的数据包其源IP地址都转换外网接口的公网,则需要执行以下iptables命令。
  22. iptables -t nat -A POSTROUTING -s 10.1.1.0/24 ! -o br0 -j MASQUERADE
  23. # 测试运行
  24. ip netns exec ns1 ping 114.114.114.114

DNAT


简单来说:从外到内的访问。
当内部需要对外提供服务时,外部发起主动连接,路由器或着防火墙的网关接收到这个连接,然后把连接转换到内部,此过程是由带公有ip的网关代替内部服务来接收外部的连接,然后在内部做地址转换,此转换称为 DNAT

  1. docker run --name dnat -p 2022:22 --privileged=true -td centos:7 /sbin/init
  2. docker exec -it dnat bash
  3. yum -y install net-tools
  4. # 安装ssh访问服务
  5. yum -y install openssh-server
  6. # 修改密码
  7. passwd root
  8. # 启动ssh与查看状态
  9. systemctl restart sshd
  10. netstat -an | grep 22


在主机上查看iptables的记录。
大致意思如下:当收到不是docker0网桥过来的包,放问2022端口的时候,将进行DNAT到我们刚刚创建的容器IP172.18.0.2:22中。

  1. iptables-save | grep 2022


接着我们通过刚刚的NS1进行测试是否可以进行连接。

  1. ip netns exec ns1 ssh 10.1.1.1 -p 2022


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

C网络流读取(图片)

stringurl="...."; Streamstream=WebRequest.Create(url).GetResponse().GetResponseStream(); constintbuffer...

C根据网络适配器获取本机ip

直接调用下面方法即可:privateIList<string>GetHostIpForFas() { try { IList<string>strIp=newList<s...

Signalr 网络通讯

电脑坏境不支持websocket(html5),选用webscoket,这个技术是真正可以做到及时通讯。如果不支持他会他会选择长连接或者轮...

Pod中的网络通信方式

前言欢今天来讲讲pod中的各种网络的通信目录:Cluster IPTarget PortsNodePortIngressLoad BalancerCluster IP创建Kubernet...

kubectl proxy 让外部网络访问K8S service的ClusterIP

kubectl proxy 让外部网络访问K8S service的ClusterIP[TOC] 使用kubectl proxy命令就可以使API server监听在本地的800...

K8s 网络(笔记)

K8s 网络(笔记)[TOC] K8s 网络 Docker容器网络回顾K8s CNIFlannel 网络插件跨node的 pod to podCluster Service是什么...

网络图片转换为Base64格式笔记

/// <summary> /// 网络图片转换为Base64格式 /// </summary> /// <param name="urlAddress&...

从工作室到公司,东途网络这些年走过的路!

东途网络从事互联网推广运营服务,在自媒体推广、自媒体运营、新闻媒体发稿、网站建设、百度推广、竞价推广、搜狗开户、 36...

新公司新产品网络营销推广方案怎么做

新公司新产品网络营销推广方案怎么做?东途网今天为您带来详细的解读!新开的公司怎么做网络营销推广、新企业该怎么做网络...

东途网教你如何利用抖音做网络推广?

抖音推广之抖音怎么推广产品?  互联网进入了短视频时代,抖音快手火山小视频成了互联网领域的新星。同时,短视频推广也...

笔记本共享外网络给台式机上网

笔记本共享外网络给台式机上网提示:我们都知道,台式电脑是不可以连接WiFi的,除非通过WiFi驱动器外接设备进行使用!那么...

.Net Core 网络打印机 乱码(伍丰)

在.net framework中正常打印.Net Core打印会出现乱码原因:.Net Core默认不支持BG2312nuget安装System.Text.Encodings.Code...

使用iPerf比较不同Docker网络设置的性能

使用iPerf比较不同Docker网络设置的性能[TOC] IPerf的介绍 iperf是一种命令行工具,用于通过测量服务器可以处理的最大网...

Kubernetes网络(IPVLANMACVLAN)

Kubernetes网络模型[TOC] 三种网络模型 在k8s中一般常见的网络模型支持三种,虚拟网桥、多路复用和硬件交换。 虚拟网...

此私有网络在该可用区无有效子网

出现错误如下: 在新建子网的时候可用区要和上面的配置一致:注意看广州三区:创建子网的时候也要选择广州三区,不然无论怎...

Kubernetes 网络MAC地址

Kubernetes 网络MAC地址[TOC] MAC简介MAC (Media Access Control) 地址用来定义网络设备的位置。MAC地址由48比特长、12位...
这一世以无限游戏为使命!
排名
2
文章
636
粉丝
44
评论
93
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术