linux下对IP地址的转发和端口的伪装----利用iptables部署

2024-01-22 11:48

本文主要是介绍linux下对IP地址的转发和端口的伪装----利用iptables部署,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原理:

地址伪装:通过地址伪装,NAT设备将经过设备的包转发到指定的接收方,同时将通过的数据包的源地址更改为其自己的接口地址。当返回的数据包到达时,会将目的地址修改为原始主机的地址并做路由。地址伪装可以实现局域网多个地址共享单一公网地址上网。类似于NAT技术中的端口多路复用(PAT)。IP地址伪装仅支持ipv4,不支持ipv6。

端口转发:也可以称之为目的地址转换或端口映射。通过端口转发,将指定IP地址及端口的流量转发到相同计算机上的不同端口,或不同计算机上的端口。一般公司内网的服务器都采用私网地址,然后通过端口转发将使用私网地址的服务器发布到公网上,以便让互联网用户访问。(例如,当接收互联网用户的HTTP请求时,网关服务器判断数据包的目标地址与目标端口,一旦匹配指定规则,则将其目标地址修改为内网真正的服务器地址,从而建立有效连接)。

两台主机部署服务,一台主机测试:

server1172.25.254.109,1.1.1.109(两块网卡)
server21.1.1.119
客户端172.25.254.19

server1端:
在这里插入图片描述

(1)关闭firewalld,下载iptables。

  • systemctl stop firewalld
  • systemctl mask firewalld
  • yum install -y iptables
    确保通过1.1.1网段两个主机可以通信:
    在这里插入图片描述
    (2)查看默认规则,清除规则
  • iptables -nL
    在这里插入图片描述
    (3)开启路由转发功能:
  • sysctl -p 查看是否开启
  • sysctl -a |grep ip_forward
  • vim /etc/sysctl.conf
    net.ipv4.ip_forward = 1
    在这里插入图片描述
    (4)设置地址伪装(实现局域网多个地址利用一个公网IP上网,在本次实验中实现1.1.1网段局域网只利用一个公网IP172.25.254.109上网,即与公网相同网段IP通信)
  • iptables -t nat -A POSTROUTING -o ens33 -j SNAT --to-source 172.25.254.109 ##-t选择表格,-A添加规则,在路由转发之后(-o指输出的网卡(ens33)即172.25.254.109这块网卡,而路由前的通信是(ens38)1.1.1.109这块网卡,两个不同网段的通信要通过路由,所以在ens33这个网卡的输出是路由后),-j指定动作,SNAT源地址转换

具体参数含义:

-t      ##指定规则表
-A      ##添加一条规则到某一条规则链中
-s      ##指定数据包的源IP地址或网段
-o      ##指定数据包从哪一块网卡发出去
-j      ##指定一个默认策略来处理数据包(动作)
--to-source    ##指定执行SNAT策略后数据包的源IP

在这里插入图片描述
server2端:
(1)添加网桥,使1.1.1.119(sever2端)能与172.25.254.109(server1端的不同网段)通信。
在这里插入图片描述
(因为1.1.1.119可以和1.1.1.109通信,因为处于同一网段,而1.1.1.109能与172.25.254.109通信,因为处于同一主机)
(2)测试:
在这里插入图片描述
(3)测试地址转发是否成功:
在这里插入图片描述
实现 了利用一个公网IP,访问外部网络的目的。
在server1端:
(1)端口转发(目的地址转换)

  • iptables -t nat -A PREROUTING -i ens33 -p tcp --dport 22 -j DNAT --to-dest 1.1.1.119 ##-i指定输出网卡,-p指定协议,–dport指定端口,DNAT目的地址转发,一个IP,一个端口,一个进程,即确定一个进程。

具体参数含义:

-t        ##指定规则表
-A        ##添加一条规则到某一条规则链中
-i        ##指定数据包从哪一块网卡进入
-j        ##指定一个默认策略来处理数据包(动作)
-p        ##指定匹配数据包的通信协议(目前DNAT只支持TCP/UDP/ICMP)
--dport   ##指定协议端口
--to--destination  ##指定执行DNAT策略后数据包的目的IP

在客户端:
本来连接的是172.25.254.109,而通过端口转发,连接到了转发地址地址1.1.1.119上。
在这里插入图片描述

这篇关于linux下对IP地址的转发和端口的伪装----利用iptables部署的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

SpringBoot配置Ollama实现本地部署DeepSeek

《SpringBoot配置Ollama实现本地部署DeepSeek》本文主要介绍了在本地环境中使用Ollama配置DeepSeek模型,并在IntelliJIDEA中创建一个Sprin... 目录前言详细步骤一、本地配置DeepSeek二、SpringBoot项目调用本地DeepSeek前言随着人工智能技

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修