Dapr 和 Docker Compose 指南

5
我一直在打转,试图弄清楚如何做到这一点,但我有以下情况。我正在尝试将 Dapr 集成到我的 ASP.NET Core 微服务中。
我按照文档(dapr init)在本地安装了 Dapr,因此我有三个本地运行的容器(dapr_redis、dapr_placement 和 dapr_zipkin),我可以通过 Docker Desktop(以及通过 docker ps)查看它们。
我有多个 ASP.NET core 微服务要运行,但每个服务都在自己的 Visual Studio 解决方案中 ... 也就是说,我没有一个包含所有微服务项目的解决方案。
我的问题是,怎样使用 Docker Compose 部署(和调试)单个微服务?我正在努力弄清楚如何将 Dapr sidecar 注入到我的微服务中,但同时让我的微服务引用现有的已运行的 Dapr 容器,如 Redis、Placement 等,这是否可能?我已经尽力遵循文档,但似乎无法使其工作。我的 compose 文件目前看起来像这样:
version: '3.4'

services:

  microservicea:
    image: ${DOCKER_REGISTRY-}microservicea
    build:
      context: .
      dockerfile: MicroserviceA/Dockerfile
    #depends_on:
    #  - redis
    #  - placement
  microservicea-dapr:
    image: "daprio/daprd:edge"
    command: ["./daprd",
      "-app-id", "microservicea",
      "-app-port", "3000",
      "-placement-host-address", "placement:50005",
      "-dapr-grpc-port", "50002",
      "-components-path", "/components"]
    depends_on:
      - microservicea
    network_mode: "service:microservicea"

如果我做错了,处理这种情况的最佳方法是什么?
我的最终目标是针对一种情况进行开发,即在处理微服务A时,需要调用另一个微服务B(Dapr服务之间的调用)。 我可以假设微服务B已经在本地构建和部署,并在其自己的容器中运行(已注入Dapr sidecar)。 我只需要一个Docker Compose文件,它将构建微服务A,注入Dapr sidecar并在本地部署容器,以便我可以进行测试和调试。
提前致谢。
1个回答

8

如果我理解你的问题正确,你应该尝试实现以下设置:

[ [SericeA]-[ServiceA-Dapr] ] -->[docker-network]<--[ [ServiceB]-[ServiceB-Dapr] ]

在这张图中,ServiceA及其Dapr sidecar加入了[docker-network]。同样适用于ServiceB及其sidecar。
如果您创建了一个新的网络:
docker network create -d bridge my-dapr-network

接着按照以下方式更新ServiceAServiceB的合成文件:

version: '3.4'

networks:
  default:
    external:
      name: my-dapr-network

services:

  microservicea:
    image: ${DOCKER_REGISTRY-}microservicea
    build:
      context: .
      dockerfile: MicroserviceA/Dockerfile

  microservicea-dapr:
    image: "daprio/daprd:edge"
    command: ["./daprd",
      "-app-id", "microservicea",
      "-app-port", "3000",
      "-placement-host-address", "placement:50005",
      "-dapr-grpc-port", "50002",
      "-components-path", "/components"]
    depends_on:
      - microservicea
    network_mode: "service:microservicea"

这里重要的部分是这一段:
networks:
  default:
    external:
      name: my-dapr-network

如果您对这两个Compose文件都进行了更改,您将能够独立启动/停止它们,并始终连接到同一个外部桥接网络。因此,它们将能够互相通信。


我的 Docker版本20.10.5 出现了 services.microservicea.networks.default包含不支持的选项:'external' 错误。可能是什么原因呢?提前感谢您的帮助。 - Slaus
1
是的,我的缩进搞错了。networks 是一个顶级条目,我已经修复了代码,感谢您指出。 - Anton Sizikov

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接