前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >linux下进行端口映射

linux下进行端口映射

作者头像
jeremyxu
发布2018-05-10 11:06:06
4.7K0
发布2018-05-10 11:06:06
举报

工作需要将某个具有外网IP的server的某个端口映射到某个内网IP的server的相同端口上。

首先想到使用NAT,命令如下

代码语言:javascript
复制
echo "1" > /proc/sys/net/ipv4/ip_forward
iptables -t nat -I PREROUTING -d $outterIP -p tcp --dport $outterPort -j DNAT --to-destination $innerIP:$innerPort
iptables -I FORWARD -p tcp -m state --state NEW,RELATED,ESTABLISHED -d $innerIP --dport $innerPort -j ACCEPT
iptables -I FORWARD -p tcp -m state --state NEW,RELATED,ESTABLISHED -s $innerIP --sport $innerPort -j ACCEPT
iptables -t nat -I POSTROUTING -s $innerIP -j SNAT --to-source $outterIP

后面发现NAT映射失败,仔细检查发现由于$outterIP并不是$innerIP的网关,从$innerIP回来的数据包直接从其网关传输走了,无法到达$outterIP所在的server, 即SNAT无法正常工作。

最后想了想,还是直接用ssh port forwarding了,命令如下

代码语言:javascript
复制
ssh -Nfq -c arcfour  -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o LogLevel=quiet -o ServerAliveInterval=15 -o ServerAliveCountMax=3 -L 0.0.0.0:8118:192.168.9.85:8118 -i /root/.ssh/id_rsa root@127.0.0.1

效率方面估计会比直接NAT端口映射差一点,但我也能接受了

最后附一张iptables数据包流转图

iptables数据包流转
iptables数据包流转

iptables数据包流转

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014-05-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档