配置iptables实现本地端口转发的方法详解

admin3年前云主机40


场景
假如你在用 resin 调试一个 Web 程序,需要频繁地重启 resin。这个 Web 程序需要开在 80 端口上,而 Linux 限制 1024 以下的端口必须有 root 权限才能开启。但是你又不愿意在调程序的时候总是开着一个 root 终端。在这种情况下,你可以把 resin 开在默认的 8080 端口上,然后使用 iptables 来实现和真的把服务开在 80 端口上一样的效果。
方法
将与 80 端口的 TCP 连接转接到本地的 8080 端口上。使用 DNAT (Destination Network Address Translation) 技术可以满足这一要求。因为 iptables 在处理本地连接和远程连接的方法不同,所以需要分开处理。下面假设本机的 IP 是 192.168.4.177。
远程连接
远程连接指的是由另外一台机器连接到这台机器上。这种连接的数据包在 iptables 会首先经过 PREROUTING 链,所以只需在 PREROUTING 链中作 DNAT。

复制代码代码如下:
# iptables -t nat -A PREROUTING -p tcp -i eth0 -d 192.168.4.177 --dport 80 -j DNAT --to 192.168.4.177:8080

本地连接
本地连接指的是在本机上,用 127.0.0.1 或者本机 IP 来访问本机的端口。本地连接的数据包不会通过网卡,而是由内核处理后直接发给本地进程。这种数据包在 iptables 中只经过 OUTPUT 链,而不会经过 PREROUTING 链。所以需要在 OUTPUT 链中进行 DNAT。除了对 127.0.0.1 之外,对本机 IP (即 192.168.4.177) 的访问也属于本地连接。

复制代码代码如下:
# iptables -t nat -A OUTPUT -p tcp -d 127.0.0.1 --dport 80 -j DNAT --to 127.0.0.1:8080
# iptables -t nat -A OUTPUT -p tcp -d 192.168.4.177 --dport 80 -j DNAT --to 127.0.0.1:8080

注意事项
你也许需要通过以下命令打开 IP 转发:

复制代码代码如下:
# echo 1 > /proc/sys/net/ipv4/ip_forward

在进行试验时,如果要重新设置 iptables,需要首先清空 nat 表:

复制代码代码如下:
# iptables -F -t nat

实例操作
这里将本地接口IP 61.144.a.b 的3389端口 转发到 116.6.c.d的3389      (主要访问到61.144.a.b的3389端口,就会跳转到116.6.c.d的3389)
1、 首先应该做的是/etc/sysctl.conf配置文件的 net.ipv4.ip_forward = 1 默认是0    这样允许iptalbes FORWARD。
2、 service iptables stop  关闭防火墙
3、 重新配置规则

复制代码代码如下:
iptables -t nat -A PREROUTING --dst 61.144.a.b -p tcp --dport 3389 -j DNAT --to-destination 116.
6.c.d:3389
iptables -t nat -A POSTROUTING --dst 116.6.c.d -p tcp --dport 3389 -j SNAT --to-source 61.144.a.b
service iptables save

        将当前规则保存到 /etc/sysconfig/iptables
        若你对这个文件很熟悉直接修改这里的内容也等于命令行方式输入规则。
5、 启动iptables 服务, service iptables start


可以写进脚本,设备启动自动运行;


复制代码代码如下:
# vi /etc/rc.local
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.</p><p>touch /var/lock/subsys/local</p><p>sh /root/myshipin.log
---------------------------------------------------------------------
vi myshipin.log
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.</p><p>iptables -F -t nat
iptables -t nat -A PREROUTING --dst 61.144.a.b -p tcp --dport 3389 -j DNAT --to-destination 116.6.c.d:3389
iptables -t nat -A POSTROUTING --dst 116.6.a.b -p tcp --dport 3389 -j SNAT --to-source 61.144.c.d
~
----------------------------------------------------------------
TCP</p><p>iptables -t nat -A PREROUTING --dst 61.144.a.b -p tcp --dport 9304 -j DNAT --to-destination 10.94.a.b:9304
iptables -t nat -A POSTROUTING --dst 10.94.a.b -p tcp --dport 9304 -j SNAT --to-source 61.144.a.b</p><p>UDP
iptables -t nat -A PREROUTING --dst 61.144.a.b -p udp --dport 9305 -j DNAT --to-destination 10.94.a.b:9305
iptables -t nat -A POSTROUTING --dst 10.94.a.b -p udp --dport 9305 -j SNAT --to-source 61.144.a.b

另:

>iptables配置文件的位置:/etc/sysconfig/iptables 外网地址发变化在配置文件里修改就可以了。《配置iptables实现本地端口转发的方法详解》来自互联网同行内容,若有侵权,请联系我们删除!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

国内云主机租赁:性价比之选

随着云计算技术的快速发展,云主机租赁成为越来越多企业部署IT应用和服务的首选。本文以国内云主机租赁:性价比之选为中心,从价格、性能、可靠性和服务方面分析了国内云主机市场,为读者提供选购参考。一、价格—...

加拿大云服务器

什么是加拿大云服务器?加拿大云服务器是一种基于云计算技术的服务器,其主要特点是灵活性高、可扩展性强、性能稳定等。用户可以通过远程方式连接到云服务器,进行自己所需的操作,而不必以自己的计算机为基础。在加...

香港服务器网络中断的原因是什么(揭秘香港网络中断原因)

一、网络硬件故障网络硬件故障是一种最常见的网络中断原因,香港服务器也不例外。其中,路由器失效是一个常见的问题,如果在服务器的路由器上发生故障,就会导致服务器无法连接到互联网。数据中心故障也同样常见,其...

宿迁高防服务器租用选哪家好?租用宿迁高防服务器价格是多少?

随着互联网的飞速发展,整个IDC产业也发展迅速。与此同时,互联网也遭遇到网络流量的严重攻击,恶意攻击者所控制的肉鸡攻击也越来越凶猛。在这样的环境下,不少企业网站遭到攻击,很多的用户因为各类网络攻击损失...

云个人虚拟主机

云个人虚拟主机的基本介绍云个人虚拟主机是一种基于互联网的技术和服务,通过使用虚拟化技术,将一台服务器的资源分隔成多个虚拟主机,每个虚拟主机可独立配置自己的操作系统、服务器软件和数据,从而实现互不影响、...

介绍一下高防服务器?美国100G高防服务器怎么样?

现在的网络恶意攻击日益频繁,让很多企业疲于应付,时常担心自己的网站被攻击了可怎么办。而高防服务器的出现,解决了企业长期被困扰的问题,它能防御网络的恶意攻击,保障企业网站正常运行。很多企业在选择高防服务...