对 dapr 和 docker 来说非常新。
我跟着 dapr 开始。简单的 hello world 状态管理示例运行良好。是的布鲁斯,我们都知道你是蝙蝠侠。
所以接下来我为 .NET Core 构建了天气预报多容器示例。这很好用。(我将我的前端剃须刀页面命名为“wxui”,将后端 webapi 命名为“wxapi”)。
最后,我想尝试在天气预报示例中添加状态管理。我修改了前端 Razor Pages 应用程序来存储和检索一些状态,并在我的 docker-compose 文件中添加了一个 redis 容器。
事情进展不顺利。
wxui-dapr 容器正在退出并显示以下消息:
time="2021-05-20T22:47:50.3179068Z" level=fatal msg="process component statestore error: redis store: 在 localhost:6379 连接到 redis 时出错: dial tcp 127.0.0.1:6379: connect: connection denied" app_id=wxui instance=69254f9724b0 scope=dapr.runtime type=log ver=1.1.2
我猜测 dapr sidecar 容器没有将本地端口 6379 映射到 redis 容器。但我不知道如何测试或修复它。
这是我的 docker-compose.yml 文件,如果有用的话:
version: '3.4'
services:
redis:
image: "redis:alpine"
ports:
- "6379:6379"
networks:
- wx-hello-world
wxui:
image: ${DOCKER_REGISTRY-}wxui
build:
context: .
dockerfile: WxUI/Dockerfile
ports:
- "51000:50001"
networks:
- wx-hello-world
depends_on:
- redis
wxui-dapr:
image: "daprio/daprd:latest"
command: [ "./daprd", "-app-id", "wxui", "-app-port", "80", "-components-path", "/components" ]
volumes:
- "./components/:/components"
depends_on:
- wxui
network_mode: "service:wxui"
wxapi:
image: ${DOCKER_REGISTRY-}wxapi
build:
context: .
dockerfile: WxAPI/Dockerfile
ports:
- "52000:50002"
networks:
- wx-hello-world
wxapi-dapr:
image: "daprio/daprd:latest"
command: [ "./daprd", "-app-id", "wxapi", "-app-port", "80" ]
depends_on:
- wxui
- wxapi
network_mode: "service:wxapi"
networks:
wx-hello-world:
我可以根据需要(要求)提供其他日志或数据。
谁能帮我找出导致wxui-dapr
容器退出的原因,以及如何解决它?谢谢!