需求
外网需要访问内网的redis(无公网ip)服务器A,而它只能通过内网访问,其中服务器B有公网和内网地址,B通过内网可以访问A的服务;这时可以通过端口转发,通过访问B的端口来实际访问A的redis服务
解决方案
1 2 3 4 5 6 7 8 9 10 11
| echo '1' > /proc/sys/net/ipv4/ip_forward sysctl -p iptables -A FORWARD -m state --state ESTABLISHED,RELATED -j ACCEPT iptables -A FORWARD -d 10.10.10.12 -p tcp --dport 6379 -j ACCEPT iptables -t nat -A PREROUTING -d 120.27.114.114 -p tcp -m tcp --dport 6379 -j DNAT --to-destination 10.10.10.12:6379 iptables -t nat -A POSTROUTING -d 10.10.10.12 -p tcp -m tcp --dport 6379 -j SNAT --to-source 10.10.10.10 iptables-save > /etc/iptables/rules.v4 iptables-restore < /etc/iptables/rules.v4
|