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

相关文章

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令