1

使用 Azure IoT Edge,我还没有找到任何方法来保证部署中容器/模块的初始化顺序。例如,假设我有 2 个模块,A 和 B。A 是服务器,B 是依赖于 A 的客户端。据我所知,无法保证 A 在 B 之前启动。

Azure IoT Edge 部署模板符合 Docker 引擎 API,我找不到任何方法通过该 API 强制执行依赖项。作为一种解决方法,我不假设每个容器的代码中运行了哪些容器。这可行,尽管额外代码的开销并不理想,特别是考虑到像 docker-compose 这样的工具会使执行初始化顺序变得相当简单。

我想做这样的事情(src:https ://docs.docker.com/compose/compose-file/ ):

version: "3.7"
services:
  web:
    build: .
    depends_on:
      - db
      - redis
  redis:
    image: redis
  db:
    image: postgres

作为一种解决方法,并按照上面的示例,在web容器中我一直在执行以下操作,以确保在执行相关操作postgres之前启动并运行:webpostgres

postgresIsUp = False
while not postgresIsUp:
    try:
        pingPostgres()
        postgresIsUp = True
    except PingError:
        print("postgres is not yet running")

当然,这是一个带有明显缺陷的人为示例,但它展示了解决方法的要点。

4

2 回答 2

1

不,IotEdge 不支持按特定顺序初始化模块。请注意,即使可以按特定顺序启动它们以解决依赖关系,如果其中一个模块崩溃,您仍然会遇到问题。它将由 EdgeHub 重新启动,但您会失去初始化的顺序。

Mike Yagley(IotEdge 的贡献者之一)在github上对此问题进行了解释。

于 2019-05-09T06:09:19.553 回答
0

StartupOrder:在 IoT Edge 版本 1.0.10 中引入。首次部署时,IoT Edge 代理应按哪个顺序启动模块。

于 2020-11-05T07:53:43.597 回答