java Docker:无法连接到弹性搜索表单spring boot Docker映像
停靠的Spring Boot应用程序无法连接到以默认地址和端口在本地运行的弹性搜索服务器。引发以下异常:
2018-01-20 07:10:38.529 INFO 1 --- [ main] org.elasticsearch.client.transport : [Gemini] failed to connect to node [{#transport#-1}{localhost}{127.0.0.1:9300}], removed from nodes list
org.elasticsearch.transport.ConnectTransportException: [][127.0.0.1:9300] connect_timeout[30s]
at org.elasticsearch.transport.netty.NettyTransport.connectToChannelsLight(NettyTransport.java:967) ~[elasticsearch-2.4.6.jar!/:2.4.6]
at org.elasticsearch.transport.netty.NettyTransport.connectToNode(NettyTransport.java:933) ~[elasticsearch-2.4.6.jar!/:2.4.6]
at org.elasticsearch.transport.netty.NettyTransport.connectToNodeLight(NettyTransport.java:906) ~[elasticsearch-2.4.6.jar!/:2.4.6]
at org.elasticsearch.transport.TransportService.connectToNodeLight(TransportService.java:267) ~[elasticsearch-2.4.6.jar!/:2.4.6]
at org.elasticsearch.client.transport.TransportClientNodesService$SimpleNodeSampler.doSample(TransportClientNodesService.java:390) ~[elasticsearch-2.4.6.jar!/:2.4.6]
Docker文件:
FROM openjdk:8
ADD target/CryptoAPI-1.0.0.jar CryptoAPI.jar
EXPOSE 80
ENTRYPOINT ["java", "-jar", "CryptoAPI.jar"]
运行映像的Docker命令:
docker run --net=host cryptoapi
# 1 楼答案
如果您访问docker容器中的
127.0.0.1
,它将尝试连接到自身(在您的示例中,带有spring boot的容器将尝试访问其9300端口)。容器不知道也不应该知道周围环境的任何信息——这是dockers的核心原则有一些变通办法,请参见此thread on docker forum。但一般的想法是,您不应该试图从容器中访问主机
正确的方法是在容器内开始弹性搜索,建立docker网络,并通过名称(docker网络内的域名)在两个容器之间进行通信