为什么部署在Docker容器上的Spring Cloud Netflix应用程序需要显式设置eureka.instance.hostname?
作者:互联网
一个简单的场景:
> 2台eureka服务器(http://archimedes1 http://archimedes2)
> 1个配置服务器
> 1个Zull网关
> 1个企业微服务
部署在localhost上,一切正常.
我对它们进行了docker化,使其可以在每个应用程序的单独容器上运行,并在Windows上的Docker上进行了测试.
部署(配置服务器,zull和b-ms)后,我看到的是,如果我不为它们中的每一个都指定eureka.instance.hostname,它们将使用无效的URL在Eureka服务器中注册.由于它们获取的URL无效,因此无法彼此调用.
例如:
CONFIGSERVER n/a (1) (1) UP (1) - 287dd3ada410:configserver:8888
287dd3ada410:configserver:8888指向287dd3ada410:8888 / info.而且这不存在.
要解决此问题,我必须添加到configserver的application.yml(以及其他应用程序的等效文件):
eureka:
instance:
hostname: config-server
现在它像这样在尤里卡出现:
CONFIGSERVER n/a (1) (1) UP (1) - c99cdfe9bd01:configserver:8888
并且c99cdfe9bd01:configserver:8888指向http:// config-server:8888 / info,它现在可以正确解析配置服务器.
为什么每个服务都必须使用eureka.instance.hostname?为什么没有在没有Docker(c99cdfe9bd01:configserver:8888-> 192.168.99.100:8888)的情况下运行时,他们为什么不向IP:port注册?
解决方法:
我相信每个Docker容器都需要使用Docker主机IP和映射到该容器端口的Docker主机端口进行注册.
这是我用过的:
尤里卡实例:
docker run -idt -p 8001:8001 --net=host -e spring.profiles.active=peerAware -e appPort=8001 -e hostName=$HOSTNAME -e dataCenter=asimio-cloud-dal -e environment=staging -e peerUrls="http://$HOSTNAME:8002/eureka/" asimio/discovery-server:1.0.73
服务实例:
docker run -idt -p 8601:8601 --net=host -e appPort=8601 -e hostName=$HOSTNAME -e eureka.client.serviceUrl.defaultZone="http://$HOSTNAME:8001/eureka/,http://$HOSTNAME:8002/eureka/" asimio/demo-registration-api-2:1.0.21
标签:netflix-eureka,spring-cloud-netflix,docker,spring-cloud,spring 来源: https://codeday.me/bug/20191118/2024540.html