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