[英]node.js, Rabbitmq & Docker: the service using seneca seems to start before rabbitmq
我使用docker创建多个容器,其中一个包含rabbitmq实例,另一个包含应该响应队列活动的node.js操作。 遍历docker-compose日志,我看到很多ECONNREFUSED错误,然后我看到该行开始表明rabbitmq已经在它的容器中启动了。 这似乎表明,rabbitmq似乎是在需要它的服务之后开始的。
作为侧边栏,只是为了消除任何其他可能的原因,这是node.js连接到rabbitmq的连接字符串:
amqp://rabbitmq:5672
这里是docker-compose.yaml文件中rabbitmq的条目:
rabbitmq:
container_name: "myapp_rabbitmq"
tty: true
image: rabbitmq:management
ports:
- 15672:15672
- 15671:15671
- 5672:5672
volumes:
- /rabbitmq/lib:/var/lib/rabbitmq
- /rabbitmq/log:/var/log/rabbitmq
- /rabbitmq/conf:/etc/rabbitmq/
service1:
container_name: "service1"
build:
context: .
dockerfile: ./service1.dockerfile
links:
- mongo
- rabbitmq
depends_on:
- mongo
- rabbitmq
service2:
container_name: "service2"
build:
context: .
dockerfile: ./service2/dockerfile
links:
- mongo
- rabbitmq
depends_on:
- mongo
- rabbitmq
这个时间问题的解决方案是什么?
如何在消耗容器启动之前启动rabbitmq?
如果这不是时间问题,请告诉我,但是配置。 我列出的docker-compose.yml条目中的问题?
看起来你没有包含完整的docker-compose文件。 我希望在compose中看到你的节点容器。 我认为问题是你需要一个
depends_on:
- "rabbitmq"
在docker compose的节点容器部分中
有关撰写依赖项的更多信息,请访问: https : //docs.docker.com/compose/startup-order/
请注意,正如此页面建议您应该这样做,以使您的应用程序能够适应外部服务的中断。
您需要控制从属容器的启动过程。 下面的文件相同
https://docs.docker.com/compose/startup-order/
我通常使用下面项目中的wait-for-it.sh
文件
https://github.com/vishnubob/wait-for-it
所以我的service1
会有一个下面的命令
wait-for-it.sh rabbitmq:5672 -t 90 -- command with args to launch service1
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.