我编写了一个监听tcp 9999和udp 9966的simiple程序,并将程序包装到这样的docker容器中:
FROM jeanblanchard/busybox-java
ADD testprg /opt/testprg
EXPOSE 9999
EXPOSE 9966/udp
ENTRYPOINT ["/opt/testprg/start.sh"]
然后像这样运行码头:
docker run -d -P testprg
和docker ps -a
结果(PORTS部分):
0.0.0.0:14355->9966/udp, 0.0.0.0:14337->9999/tcp
一切看起来都很顺利,我可以telnet到localhost 14337
并获得响应,但不是来自远程机器。我尝试使用lsof -i :14337
或netstat -nat | grep docker
,什么都没有。
我还尝试添加iptable
这样的路线:
sudo iptables -t nat -A PREROUTING -i 192.168.1.101 -p tcp --dport 14355 -j REDIRECT --to-port 9999
另外,从远程机器中得不到任何东西。所以,我的问题是,如何将程序公开的端口重定向到我的主机之外?
答案 0 :(得分:0)
哈哈,对不起,我的错误,我的远程计算机与我的主机不在同一个网络中,这个配置就像一个魅力。