Compartir a través de

用于设备到云的 IoT 中心消息的消息扩充

“消息扩充”是 IoT 中心在将消息发送到指定的终结点之前,使用附加的信息为消息添加戳记的功能。 使用消息扩充的原因之一是包含可用于简化下游处理的数据。 例如,使用设备孪生标记扩充设备遥测消息可以减少客户对此信息发出设备孪生 API 调用所造成的负载。

Message enrichments flow

消息扩充具有三个关键元素:

  • 扩充名称或键

  • 要对其应用扩充的一个或多个终结点

是一个字符串。 键只能包含字母数字字符或以下特殊字符:连字符 (-)、下划线 (_)和句点 (.)。

可以是以下任一示例:

  • 任意静态字符串。 不允许条件、逻辑、操作和函数等动态值。 例如,如果你开发由多个客户使用的 SaaS 应用程序,可为每个客户分配一个标识符,并使该标识符在应用程序中可用。 当该应用程序运行时,IoT 中心会使用客户的标识符来戳记设备遥测消息,从而可为每个客户以不同的方式处理消息。

  • 发送消息的 IoT 中心的名称。 此值为 $iothubname

  • 设备孪生中的信息,例如其路径。 示例包括 $twin.tags.field$twin.tags.latitude

    注意

    目前,只有 $iothubname、$twin.tags、$twin.properties.desired 和 $twin.properties.reported 是消息扩充支持的变量。 此外,扩充仅支持基元类型。 不能使用对象类型扩充消息。

消息扩充将作为应用程序属性添加到发送到所选终结点的消息中。

应用扩充

消息可能来自 IoT 中心消息路由支持的任何数据源,包括:

  • 设备遥测数据,例如温度或压力
  • 设备孪生更改通知 - 设备孪生中发生的更改
  • 设备生命周期事件,例如创建或删除了设备时

可将扩充添加到正在发往 IoT 中心内置终结点的消息,或添加到正在路由到自定义终结点(例如 Azure Blob 存储、服务总线队列或服务总线主题)的消息。

还可以通过先创建具有设备遥测消息类型的事件网格订阅,向要发布到事件网格的消息添加扩充。 基于此订阅,我们将在 Azure IoT 中心为遥测创建默认路由。 此单一路由可以处理你的所有事件网格订阅。 然后,可以使用 IoT 中心“消息路由”部分的“扩充消息”选项卡为终结点配置扩充。 有关使用事件网格对事件做出响应的信息,请参阅 Iot 中心和事件网格

扩充是按终结点应用的。 如果指定要为特定终结点戳记五个扩充,则发往该终结点的所有消息都将使用五个相同的扩充进行戳记。

可使用以下方法配置扩充:

方法 命令
门户 Azure 门户请参阅消息扩充教程
Azure CLI az iot hub message-enrichment
Azure PowerShell Add-AzIotHubMessageEnrichment

添加消息扩充不会增加消息路由的延迟。

若要尝试消息扩充,请参阅消息扩充教程

限制

  • 对于标准或基本层中的每个 IoT 中心,最多可以添加 10 个扩充。 对于免费层中的 IoT 中心,最多可以添加 2 个扩充。

  • 在某些情况下,如果你要使用设置为设备孪生中的标记或属性的值扩充消息,该值将戳记为字符串值。 例如,如果某个扩充值设置为 $twin.tags.field,则会使用字符串“$twin.tags.field”而不是孪生中该字段的值来戳记消息。 这适用于以下情况:

    • IoT 中心位于基本层中。 基本层 IoT 中心不支持设备孪生。

    • IoT 中心位于标准层中,扩充值使用的设备孪生路径不存在。 例如,如果扩充值设置为 $twin.tags.location,并且设备孪生在标记下没有位置属性,该会使用字符串“$twin.tags.location”戳记消息。

    • IoT 中心位于标准层中,但扩充值使用的设备孪生路径会解析为一个对象,而不是一个简单的属性。 例如,如果扩充值设置为 $twin.tags.location,并且标记下的 location 属性是一个包含子属性(例如 {"building": 43, "room": 503})的对象,则系统会使用字符串“$twin.tags.location”来标记该消息。

  • 对设备孪生所做的更新最长可能需要在五分钟后才反映在相应的扩充值中。

  • 总消息大小(包括扩充)不能超过 256 KB。 如果消息大小超过 256 KB,IoT 中心会丢弃消息。 如果丢弃了消息,可以使用 IoT 中心指标来识别和调试错误。 例如,可监测路由指标中的“不兼容的遥测消息”(“d2c.telemetry.egress.invalid”)。 有关详细信息,请参阅监视 IoT 中心

  • 消息扩充不适用于数字孪生体更改事件。

  • 模块不会从其对应的设备继承孪生标记。 对源于设备模块(例如来自 IoT Edge 模块)的消息进行扩充必须使用在模块孪生体上设置的孪生体标记。

定价

使用消息扩充不会产生额外的费用。 目前,将消息发送到 IoT 中心需要付费。 即使消息要发往多个终结点,也只需支付该消息的费用一次。

后续步骤

请查看以下文章来详细了解如何将消息路由到 IoT 中心: