gpt4 book ai didi

amazon-web-services - ECS on EC2 同一任务中两个容器之间的双向通信

转载 作者:行者123 更新时间:2023-12-04 08:15:04 24 4
gpt4 key购买 nike

我正在尝试在 EC2 实例上配置 ECS 任务。任务定义中的网络模式为 Bridge
我的任务里面有两个容器,它们应该相互通信。例如ContainerA 向ContainerB 发出请求,ContainerB 向ContainerA 发出请求。
当我使用 docker-compose 时一切正常,容器可以通过它们的名称进行通信。但是当我在 ECS 上部署时,这些容器彼此看不到。部分我可以使用任务定义中的链接解决这个问题,但是,它只能在一个方向上工作,我的意思是如果为两个容器设置链接,我会在创建任务定义期间收到这样的错误消息:

Unable to create a new revision of Task Definition web-app:12Container links should not have a cycle


很高兴听到任何想法,我错过了什么以及是否真的可能。老实说,我认为一个任务中的容器应该通过容器名称自动通信,尤其是当它们在同一个 Bridge 网络下时。
我知道有一个功能服务发现允许通过名称在服务之间进行通信,但我仍然希望有一个带有两个容器的服务和任务。
感谢您的任何帮助。
ContainerA NETWORK SETTINGS

最佳答案

如果两个容器都定义在同一个任务定义中,它们可以通过 localhost 获得。 :
例如,如果 ContainerA 正在监听端口 8081,而 ContainerB 正在监听端口 8082,则它们可以通过以下方式简单地相互访问:

localhost:8081
localhost:8082
旁注:与具有两个容器的 Kubernetes pod 中的概念相同 - 它们可以通过 localhost 访问
编辑 :这与 awsvpc 相关您可以在 documentation 中看到的网络模式:

containers that belong to the same task can communicate over thelocalhost interface

关于amazon-web-services - ECS on EC2 同一任务中两个容器之间的双向通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65747875/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com