使用iptables的DNAT实现端口转发

原因

因为项目中需要使用K8S连接harbor环境,但是harbor又用F5做了高可用映射,端口为18080,但是K8S集群中的下载镜像地址都是80,因此想通过Dnat来实现端口转发,即把本机的80转到F5地址的18080

示例

K8S主机:192.168.1.100
F5地址:192.168.2.100
harbor地址:192.168.3.100
目的就是为了把192.168.1.100:80转发至192.168.2.100:18080上

脚本

#开启内核转发`在这里插入代码片`
echo "net.ipv4.ip_forward=1" >> /etc/sysctl.conf
sysctl -p
#开启DNAT,这个是在PREROUTING中的配置
iptables -t nat -A PREROUTING -p tcp -d 192.168.1.100 --dport 80 -j DNAT --to 192.168.2.100:18080
#还需要做个SNAT,这个是在POSTROUTING 中配置的,为转发请求指明请求来源,也就是转发是通过192.168.1.100来转发的,即到192.168.2.100的ip是1.100
iptables -t nat -A POSTROUTING -p tcp -d 192.168.2.100 --dport 18080 -j SNAT --to 192.168.1.100

问题

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值