Dapr 和 Docker Compose 指南

2024-04-18

我正在绕圈试图找出如何做到这一点,但我遇到了以下情况。我正在尝试将 Dapr 合并到我的 ASP.NET Core 微服务中。

我已按照文档在本地安装了 Dapr (dapr init),结果我有三个本地运行的容器(dapr_redis, dapr_放置 and 达普拉拉链)我可以通过 Docker Desktop 查看(以及通过docker ps).

我有许多 ASP.NET Core 微服务要运行,但每个服务都在自己的 Visual Studio 解决方案中...也就是说,我没有一个包含所有微服务项目的解决方案。

我的问题是,如何使用 Docker Compose 部署(和调试)单个微服务?我正在尝试弄清楚如何将 Dapr sidecar 注入到我的微服务中,同时让我的微服务引用现有且已在运行的 Redis、Placement 等 Dapr 容器。这可能吗?我已尽力遵循文档,但我似乎无法使其正常工作。我的撰写文件当前如下所示:

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 并在本地部署容器,以便我可以测试和调试。

提前致谢。


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

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

在这张图上ServiceA及其 Dapr 边车加入[docker-network]。同样适用于ServiceB还有它的边车。

如果您创建一个新网络:

docker network create -d bridge my-dapr-network

然后更新您的撰写文件ServiceA and ServiceB这边走:

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

如果您对两个撰写文件进行更改,您将能够独立启动\停止它们,并且它们将始终加入相同的现有外部桥接网络。结果,他们将能够进行交流。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Dapr 和 Docker Compose 指南 的相关文章

随机推荐