Linux环境下实现端口转发

需求: A机器有公网,B机器无公网,需要将B机器的服务端口借助A机器发布至公网

描述:利用iptables来实现DNAT和SNAT转发

前提: 1. A\B机器都在同一内网环境下

2. A机器为Linux操作系统(Linux可开启内核转发)

3. 安全组ACL无拦截限制,服务器内部防火墙无拦截限制,SElinux无限制

操作过程:

以下命令均在A机器上操作 A机器IP 9.8.7.6 B机器IP 1.2.3.4

iptables -t nat -I PREROUTING -d 9.8.7.6 -p tcp --dport 1009 -j DNAT --to-destination 1.2.3.4:80

#创建DNAT规则,将来自本机9.8.7.6:1009的访问转发至1.2.3.4:80

iptables -t nat -A POSTROUTING -d 1.2.3.4 -p tcp --dport 80 -j SNAT --to-source 9.8.7.6

#创建SNAT规则,将访问源为9.8.7.6:1009的出请求转发至本机9.8.7.6的随机端口,ps.-to-source 如果指定固定端口的话会有异常 服务器请求80端口的时候是随机发起的端口

echo "net.ipv4.ip_forward = 1" >>/etc/sysctl.conf && sysctl -p

## 开启内核转发

最后验证访问即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值