2

Edge Module 节点客户端无法通过 MQTT 连接到 Edge Hub。它抛出一个证书错误 - NotConnectedError: unable to get local issuer certificate

Cert 为客户端设置了一个选项,

var certFile = process.env.EdgeModuleCACertificateFile;
var connectionString = process.env.EdgeHubConnectionString
var Protocol = require('azure-iot-device-mqtt').Mqtt;
var Client = require('azure-iot-device').Client;
var client = Client.fromConnectionString(connectionString, Protocol);

var options = {
    ca: fs.readFileSync(certFile,'utf-8').toString(),
};
client.setOptions(options,()=>{
    console.log('Client transport option set');
});
client.open(connectCallback);
4

1 回答 1

1

如果不了解有关您的环境的一些详细信息,我会忍不住:
您是否在 docker 容器中运行?
你用的是什么基础镜像?
你是如何启动容器的——你是手动启动它还是让 EdgeAgent 为你启动它?

您可以尝试几件事:

1) 验证您使用的是@modules-preview 代码。NPM 使这很容易出错。

PS F:\temp> npm list | findstr "azure-iot"
+-- azure-iot-device-mqtt@1.4.0-modules-preview
| +-- azure-iot-common@1.5.0-modules-preview
| +-- azure-iot-device@1.4.0-modules-preview
| | +-- azure-iot-http-base@1.3.3-modules-preview
| +-- azure-iot-mqtt-base@1.3.3-modules-preview

2) 验证您的连接字符串格式正确。它需要具有 moduleId= 和 gatewayHostName= 值。gatewayHostName 应该引用您的 edgeHub 主机。

3) 验证 EdgeModuleCACertificateFile 中引用的证书文件是否存在并且看起来像一个有效的 PEM 文件(例如,包含在 -----BEGIN CERTIFICATE-----/-----END CERTIFICATE---- 中的文本文件与一堆之间的编码文本行数)。

于 2018-04-24T19:52:16.947 回答