Open oottka opened 3 years ago
@oottka thanks for reporting this issue. Could you clarify why is ipc needed instead of defining routes between modules?
In this case we are using Azure LVA on IoT Edge, and have an inferencing module that uses the gRPC interface and shared memory to share frames (using the second option, "When communicating with a gRPC server running in another IoT Edge module"). This is the recommended approach for high-performance inferencing in LVA.
The edge deployment manifest used here is just for demo/bug reporting purposes. It does not contain a real inferencing module, but still can be used to reproduce and validate the issue.
@oottka
Thank you for reporting the issue. The issue is now in our backlog. We will circle back when we have an update.
If this is blocking you, please let us know the business impact and justification.
Thanks! There is a workaround available for this issue in the meantime: it is possible to use an external templating tool to change container:
to service:
when using iotedgehubdev.
When using a deployment manifest that specifies an IpcMode in hostconfig that accesses shared memory in another container,
iotedgehubdev start
fails due to a nonexistent container error.Relevant version numbers:
with docker-compose versions prior to 1.27.0 a different error message is thrown.
Sample deployment manifest
Note the IpcMode set in lvaEdge and rtpsim. The actual containers used do not matter; any containers that use that use these ipcmode settings will trigger the issue.
Steps to reproduce
Possible solution
The IoT Edge deployment manifest module createOptions uses docker create options. The docker create container options allow the following values:
However iotedgehubdev uses docker-compose to start the deployment. docker-compose requires the use of the setting
ipc: "service:[service name]"
when referring to another service in the same compose file. If the IpcMode value of rtpsim in the manifest above is changed fromcontainer:lvaEdge
toservice:lvaEdge
iotedgehubdev is able to start up the solution as expected. This however will not work when deploying to a real edge device, as theservice:
syntax is not supported by docker create ("Error": "Invalid IPC mode: service:lvaEdge"
).network _mode may also suffer from the same issue.