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

SNAT与DNAT

一、SNAT策略概述

1、SNAT 策略的典型应用环境

局域网主机共享单个公网IP地址接入Internet(私有IP不能在Internet中正常路由)

局域共享上网

2、 SNAT 策略的原理

修改数据包的源地址

把从内网 --> 外网的数据的源内网地址转换成公网源地址 

 

3、SNAT转换前提条件 

  • 局域网各主机已正确设置IP地址、子网掩码
  • 局域网各主机正确设置默认网关地址
  • Linux网关支持IP路由转发

 

临时打开的方法:
echo 1 > /proc/sys/net/ipv4/ip_forward
或
sysctl -w net.ipv4.ip_forward=1#只能临时生效,重启服务器之后会返回为0

永久打开的方法:vim /etc/sysctl.conf
net.ipv4.ip_forward = 1 		#将此行写入配置文件sysctl -p 						#读取修改后的配置

4、配置SNAT 内网连接外网实现源地址转换

第一步:准备虚拟机

准备三台虚拟机;一台当作网关服务器;一台当作外网web服务器;一台当作内网客户机;为了区分内网和外网的区别,设置两个VMnet;VMnet1作为内网;VMnet2作为外网

第二步:为网关服务器添加配置 

(1)多添加一个网络适配器

 

(2)修改网卡和新网卡配置

(3)网关服务器设置同意路由转发

#永久启用
vim /etc/sysctl.confnet.ipv4.ip_forward=1 sysctl -p 
#若 net.ipv4.ip_forward=0 即无法连通外网地址

第三步:配置客户机

第四步:配置外网web服务器

(1)配置网卡

 (2)安装并启动httpd软件

yum install -y httpd 
systemctl restart httpd
netstat -lntp | grep :80   #查看软件是否开启

第五步:关闭防火墙和syslinux

systemctl stop firewalld
setenforce 0

第六步:配置SNAT源地址转换

iptables -t nat -A POSTROUTING -s 192.168.10.0/24 -o ens36 -j SNAT --to 12.0.0.10

第七步:在内网ping外网服务器,并用tcpdump抓包工具查看信息

内网:  ping -c 10 12.0.0.20            #先ping外网:
tcpdump -i ens33 -s 0 -w ./test2.cap   #再tcpdump抓包;内网ping完后sz test1.cap 到真机文件中,使用 winsharp 进行查看抓包

二、DNAT策略 

1、工作原理

 2、应用场景

3、DNAT转换的前提条件 

局域网的Web服务器能够访问Internet

网关的外网IP地址有正确的DNS解析记录

Linux网关支持IP路由转发

 

4、配置DNAT 

准备虚拟机设置IP地址和网关 

将一台主机放在内网,作为Web服务器,两台作为客户端放在外网,一台作为网关务器 

与DNAT实验时相反,这次的web服务器在内网环境,服务机在公网环境

准备DNS服务器给外网客户端使用

yum install -y bind

vim /etc/named.conf

vim /etc/named.rfc1912.zones 

 

cd /var/named/
cp -p named.localhost xy101.com.zonevim xy101.com.zone

 

systemctl start named
systemctl enable named

 去客户机验证

vim /etc/resolv.conf
nameserver 12.0.0.30
nsloookup www.xy101.com

配置内核配置文件,添加ip_forward 实现路由转发功能的开启

vim /etc/sysctl.confnet.ipv4.ip_forward = 1保存退出之后 
sysctl -p

客户机验证

ping 192.168.80.30
ping 12.0.0.30
ping 12.0.0.100
ping 12.0.0.200

作DNAT转换

用客户机做网页查询;没有任何反应

添加配置即可实现访问网址 ;(先关闭防火墙)
 

iptables -t nat -A PREROUTING -i ens33 -d 12.0.0.30 -p tcp --dport 80 -j DNAT --to 192.168.80.15:80

实现远程登录Web服务器

iptables -t nat -A PREROUTING -i ens33 -d 12.0.0.30 -p tcp --dport 2345 -j DNAT --to 192.168.80.15:22

http://www.lryc.cn/news/368595.html

相关文章:

  • MySql八股文知识点总结,一篇文章让mysql成为面试加分项
  • Python 很好用的爬虫框架:Scrapy:
  • C/C++|关于 namespace 在C++中的代码组织
  • selenium自动化测试入门 —— 上传文件
  • C# Math.Round() 四舍六入五取偶
  • springboot手动触发参数校验,service层调用参数校验
  • 动手学深度学习4.10 实战Kaggle比赛:预测房价-笔记练习(PyTorch)
  • 1035 插入与归并(测试点6)
  • 什么情况下需要使用分布式事务,有哪些方案?
  • Java加密体系结构参考指南-Java Cryptography Architecture
  • C++中避免内存泄漏的方法
  • 5.1 实体完整性
  • (学习笔记)数据基建-数据质量
  • WINUI——Behavior(行为)小结
  • Ruoyi5.x RuoYi-Vue-Plus新建Translation翻译类
  • 类加载的奥秘
  • Spring知识点总结
  • STM32Cube系列教程11:STM32 AES加解密模块性能测试
  • Vue2基础:.sync修饰符的使用,认识,作用,本质案例演示,实现父子之间的通信。
  • 【数据结构与算法】使用单链表实现队列:原理、步骤与应用
  • DHCP服务
  • C++笔试-剑指offer
  • Mac安装jadx并配置环境
  • 前端学习----css基础语法
  • 超详解——python条件和循环——小白篇
  • DNS协议 | NAT技术 | 代理服务器
  • 深入ES6:解锁 JavaScript 类与继承的高级玩法
  • 领域驱动设计:异常处理
  • 网络网络层之(6)ICMPv6协议
  • 《大道平渊》· 拾壹 —— 商业一定是个故事:讲好故事,员工奋发,顾客买单。