活到老学到老  

记录遇到问题的点点滴滴。

linux配置本地tomcat应用80端口转发

8年前发布  · 1838 次阅读

linux配置本地tomcat应用80端口转发

 
场景:
本地部署tomcat到8080端口,并期望本地访问80端口来访问本地tomcat。
 
结论:
使用linux下的iptables工具实现端口转发功能。
 
具体为
 
现取得root权限
执行
iptables -t nat -I OUTPUT -p tcp  -d 127.0.0.1 --dport 80 -j REDIRECT --to-port 8080
目前在重启前均生效。要想永久生效,需要继续执行(ubuntu环境):
iptables-save > /etc/iptables.rules
新建一个bash脚本
 
#!/bin/bash  
iptables-restore < /etc/iptables.rules  
保存到/etc/network/if-pre-up.d/目录下
结束!
BTW:如果是配置外部服务器,则把第2步换为执行
iptables -t nat -I PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080
实验过程:
实验过程主要集中在上述第2步中该添加何种iptables规则。
 
取得root权限后,单独执行各个操作:
 
iptables -t nat -I OUTPUT -p tcp  --dport 80 -j REDIRECT --to-port 8080  
结果:访问本地localhost正常转发,访问外部网络全部被重定向到本地localhost:8080
原因: 本机访问请求时,本地进程产生的报文将进入OUTPUT链,因为当前请求包的端口是80,于是重定向道8080,注意是所有数据包。
 
iptables -t nat -I OUTPUT -p tcp -s 127.0.0.1 --dport 80 -j REDIRECT --to-port 8080
结果:访问本地localhost正常转发,访问外部网络正常没特殊处理
原因:类似上例,但多了一个规则:需匹配数据包源地址-s 127.0.0.1。但实际上,访问外部网络时实际数据包在经过这个链时的源地址是本机ip,而不是回路ip(127.0.0.1),所以相当于本规则对访问外部网络时无效。
 
iptables -t nat -I OUTPUT -p tcp -s 非回路网卡ip --dport 80 -j REDIRECT --to-port 8080
结果:访问本地localhost无法转发,访问外部网络全部被重定向到本地localhost:8080
原因:和上例类似,规则匹配了对外访问的数据包,从而被重定向。
 
iptables -t nat -I OUTPUT -p tcp -d 127.0.0.1 --dport 80 -j REDIRECT --to-port 8080 
结果:访问本地localhost正常转发,访问外部网络正常没特殊处理
原因:本地应用的ip被匹配上,所以访问本地应用时,数据包将被重定向道8080
 
iptables -t nat -I OUTPUT -p tcp -s 127.0.0.1 -d 127.0.0.1 --dport 80 -j REDIRECT --to-port 8080
结果:访问本地localhost正常转发,访问外部网络正常没特殊处理
原因:2,4操作的原因结合。
 
iptables -t nat -I PREROUTING -p tcp -s 127.0.0.1 -d 127.0.0.1 --dport 80 -j REDIRECT --to-port 8080
结果:访问本地localhost无法转发,访问外部网络正常没特殊处理
原因:本地连接指的是在本机上,用 127.0.0.1 或者本机 IP 来访问本机的端口。本地连接的数据包不会通过网卡,而是由内核处理后直接发给本地进程。这种数据包在 iptables 中只经过 OUTPUT 链,而不会经过 PREROUTING 链.