gpt4 book ai didi

c# - Azure IoT Edge ClientModule 无法在主机模式下连接

转载 作者:行者123 更新时间:2023-12-03 00:59:39 27 4
gpt4 key购买 nike

正如初学者 IoT Edge 开发人员所期望的那样,我开始遵循有关如何将自定义代码部署到 IoT Edge 服务器的 Microsoft 教程 Tutorial: Develop a C# IoT Edge module for Linux devices .

我能够在工业英特尔PC上安装Ubuntu 18.04服务器,下载并配置edgeHub和edgeAgent模块,创建免费的Azure和Docker Hub帐户等。甚至教程中的示例代码也成功构建并部署到我的目标设备一切看起来都很好,所有模块都在相互通信,等等。

一旦我获得了可以运行的演示代码,我就开始修改代码以更好地满足我的最终目标,即捕获我们的工业设备生成的网络流量,该设备使用 UDP 多播/广播。显然我需要配置我的 docker 镜像以在“主机”网络模式下运行。事实上,当我告诉 azure edgeAgent 以主机模式启动模块容器时,UDP 数据包就开始传入。

然而,现在我的示例模块不再能够连接到物联网集线器,我完全不知所措。我也尝试在主机模式下运行edgeHub容器,这似乎没有任何区别。我由于 ModuleClient.OpenAsync 方法而收到的确切错误是:

    Unhandled exception. System.AggregateException: One or more errors occurred. (Transient network error occurred, please retry.)
---> Microsoft.Azure.Devices.Client.Exceptions.IotHubCommunicationException: Transient network error occurred, please retry.
---> System.Net.Internals.SocketExceptionFactory+ExtendedSocketException (00000005, 0xFFFDFFFF): Name or service not known
at System.Net.Dns.InternalGetHostByName(String hostName)
at System.Net.Dns.ResolveCallback(Object context)
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw(Exception source)
at System.Net.Dns.HostResolutionEndHelper(IAsyncResult asyncResult)
at System.Net.Dns.EndGetHostAddresses(IAsyncResult asyncResult)
at System.Net.Dns.<>c.<GetHostAddressesAsync>b__25_1(IAsyncResult asyncResult)
at System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult iar, Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean requiresSynchronization)
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.Azure.Devices.Client.Transport.Mqtt.MqttTransportHandler.OpenAsyncInternal(CancellationToken cancellationToken)
at Microsoft.Azure.Devices.Client.Transport.Mqtt.MqttTransportHandler.OpenAsync(CancellationToken cancellationToken)
at Microsoft.Azure.Devices.Client.Transport.ProtocolRoutingDelegatingHandler.OpenAsync(CancellationToken cancellationToken)
at Microsoft.Azure.Devices.Client.Transport.ErrorDelegatingHandler.<>c__DisplayClass23_0.<<ExecuteWithErrorHandlingAsync>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.Azure.Devices.Client.Transport.ErrorDelegatingHandler.ExecuteWithErrorHandlingAsync[T](Func`1 asyncOperation)
--- End of inner exception stack trace ---
at Microsoft.Azure.Devices.Client.Transport.ErrorDelegatingHandler.ExecuteWithErrorHandlingAsync[T](Func`1 asyncOperation)
at Microsoft.Azure.Devices.Client.Transport.RetryDelegatingHandler.<>c__DisplayClass33_0.<<OpenInternalAsync>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.Azure.Devices.Client.Transport.RetryDelegatingHandler.EnsureOpenedAsync(CancellationToken cancellationToken)
at Microsoft.Azure.Devices.Client.InternalClient.OpenAsync()
at SampleModule.Program.Init() in /app/SampleModule/Program.cs:line 54
--- End of inner exception stack trace ---
at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
at System.Threading.Tasks.Task.Wait()
at SampleModule.Program.Main(String[] args) in /app/SampleModule/Program.cs:line 26

用于连接的代码:

ITransportSettings[] settings = { mqttSetting };
ModuleClient ioTHubModuleClient = await ModuleClient.CreateFromEnvironmentAsync(settings);
await ioTHubModuleClient.OpenAsync();
Console.WriteLine("IoT Hub module client initialized.");

很明显,ModuleClient 无法再找到 EdgeHub(名称或服务未知?)。我知道“CreateFromEnvironmentAsync”使用由edgeAgent 设置的环境变量,但是哪些变量呢?有人知道这是为什么吗?即使是指向开始调试此问题的正确方向的指针,我们也非常感激!

如果我将 Docker 容器更改回“桥接”网络,OpenAsync 方法可以完美运行,但当然,我的 UDP 广播消息将不再被接收。

最佳答案

经过一番深入研究,我自己找到了解决方案。

Module fails to restart because of transient network error

这篇文章,虽然我已经读过很多次了,但它表明/etc/hosts 文件有问题。果然,我的设备 (127.0.1.1) 的条目有问题,我一定是在某个地方更改了设备的主机名,而此更改并未反射(reflect)在主机文件中。

自该更改以来,我让 AMQP 和 MQTT 都可以工作,但是两者的 edgeHub 容器也在主机模式下运行。在桥接模式下,我遇到了一个新问题,其中 docker-proxy 没有绑定(bind)导出的端口(这导致了新的“连接被拒绝”异常)。为什么仍然是个谜......

关于c# - Azure IoT Edge ClientModule 无法在主机模式下连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62655879/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com