当您指定要监听的主机名或IP地址(在这种情况下
localhost解析为
127.0.0.1)时,服务器将仅监听该IP地址。
localhost当您在Docker容器之外时,侦听不是问题。如果您的服务器仅侦听
127.0.0.1:8000,则您的客户端可以轻松连接到该服务器,因为该连接也是从进行的
127.0.0.1。
当您在Docker容器中运行服务器时,它只会
127.0.0.1:8000像以前一样监听。该
127.0.0.1是本地环回地址,它无法访问外的容器。
当您使用来启动Docker容器时
-p8000:8000,它会将流量转发
127.0.0.1:8000到该容器的IP地址,在我的情况下为
172.17.0.2。
容器在docker0网络接口内获取IP地址(您可以通过
ip addr ls命令查看)
因此,当您的流量转发到上的容器时
172.17.0.2:8000,那里没有任何监听,并且连接尝试失败。
解决方法:
问题在于侦听地址:
server := http.Server{Addr: "localhost:8000"}要解决您的问题,请将其更改为
server := http.Server{Addr: ":8000"}这将使您的服务器侦听其容器的所有IP地址。
附加信息:
当您在Docker容器中公开端口时,Docker将创建iptables规则来进行实际转发。看到这个。您可以使用以下方法查看这些规则:
iptables -n -L iptables -t nat -n -L



