当前位置:网站首页>配置iptables实现本地端口转发的方法详解
配置iptables实现本地端口转发的方法详解
2022-04-23 01:52:00 【nginx】
场景
假如你在用 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 转发:
代码如下:
在进行试验时,如果要重新设置 iptables,需要首先清空 nat 表:
# echo 1 > /proc/sys/net/ipv4/ip_forward
代码如下:
实例操作
# 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、 重新配置规则
代码如下:
将当前规则保存到 /etc/sysconfig/iptables
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
若你对这个文件很熟悉直接修改这里的内容也等于命令行方式输入规则。
5、 启动iptables 服务, service iptables start
可以写进脚本,设备启动自动运行;
代码如下:
另:iptables配置文件的位置:/etc/sysconfig/iptables 外网地址发变化在配置文件里修改就可以了。
# 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
版权声明
本文为[nginx]所创,转载请带上原文链接,感谢
https://www.openjq.com/thread-33699-1-1.html
边栏推荐
- What are the common proxy IP problems?
- Question bank and online simulation examination for safety management personnel of hazardous chemical business units in 2022
- Jerry's CPU performance test [chapter]
- 有哪些常见的代理ip问题?
- 哪些代码需要做单元测试?
- EBS:PO_ EMPLOYEE_ HIERARCHIES_ ALL
- Learning methods and career development guide (2022 Edition)
- 什么时候应该编写单元测试?什么是TDD?
- Server 2019 the available memory of the server is half of the actual memory
- postman里面使用 xdebug 断点调试
猜你喜欢
How to choose a good dial-up server?
[experience tutorial] Alipay balance automatically transferred to the balance of treasure how to set off, cancel Alipay balance automatically transferred to balance treasure?
Analyze the advantages and disadvantages of tunnel proxy IP.
W801/W800-wifi-socket开发(一)-UDP
在使用代理IP前需要了解哪些分类?
Under the pressure of sales, domestic mobile phones began to reduce prices, but they haven't put down their final face
揭秘被Arm编译器所隐藏的浮点运算
Some tips for using proxy IP.
postman里面使用 xdebug 断点调试
J-Link RTT使用
随机推荐
The sixth season of 2022, the perfect children's model IPA national race leads the yuanuniverse track
使用单元测试框架编写单元测试的好处?
Leetcode-阶乘函数后 K 个零
Server 2019 the available memory of the server is half of the actual memory
NPM yarn startup error [resolved]
What are the benefits of writing unit tests using the unit test framework?
PHP & laravel & master several ways of generating token by API and some precautions (PIT)
拨号vps会遇到什么问题?
使用代理IP是需要注意什么?
.NET单元测试第一篇:常见.NET单元测试框架有哪些?
JSP基础知识总结
Sqlserver data transfer to MySQL
42. Use k3det in mmrotate for rotating target detection, MNN deployment and ncnn deployment
Longest common subsequence (record path version)
角色個人屬性英文縮寫
How can e-procurement become a value-added function in the supply chain?
J-Link RTT使用
K zeros after leetcode factorial function
2022第六季完美童模 IPA國民賽領跑元宇宙賽道
数字藏品平台入驻 数字藏品平台开发 数字藏品SaaS平台