在许多场景中,您需要将设备上报给物联网平台的数据进行加工处理或用于业务应用。使用物联网平台提供的服务端订阅功能和云产品流转功能,均可实现设备数据流转。本文对比物联网平台支持的各流转方案及使用场景,帮助您选择合适的流转方案。
目前,数据流转方式有两类:
- 云产品流转:提供初级的数据过滤转换能力。支持对设备数据进行过滤并转换,然后再流转到其他阿里云云产品实例。
- 服务端订阅:通过AMQP或消息服务(MNS)客户端直接获取设备消息。可快速地获取设备消息,无消息过滤和转换能力,功能较为单一,但是简单易用且高效。
云产品流转与服务端订阅对比
目前,数据流转方式有两类:
- 云产品流转:对设备数据进行过滤并转换,然后再流转到其他阿里云云产品实例。
- 服务端订阅:通过AMQP或消息服务(MNS)客户端直接获取设备消息。
两者的对比,如下表所示。
流转方式 | 使用场景 | 优缺点 | 使用限制 |
---|---|---|---|
云产品流转 |
|
优点:
缺点: 需编写SQL和配置规则,使用相对复杂。 |
请参见云产品流转使用限制。 |
服务端订阅 |
|
优点:相对简单易用且高效。 缺点:缺少过滤和转换能力。 |
请参见服务端订阅使用限制。 |
流转目标 | 使用场景 | 优点 | 缺点 |
---|---|---|---|
实例内的时序数据存储
说明 仅用户购买的企业版实例支持实例内的时序数据存储。
|
适合根据设备数据进行业务分析和监控的场景。 | 数据直接写入实例内的时序数据存储。 | 不涉及 |
消息队列RocketMQ | 要对设备数据进行复杂或精细化处理的海量设备场景。
设备消息量>1,000 QPS的场景,推荐使用消息队列 RocketMQ。 |
|
公网支持略差(铂金版公网性能较好)。 |
消息服务(MNS) | 公网环境场景下,对设备数据进行复杂或精细化处理。
设备消息量<1,000 QPS的场景,推荐使用MNS。 |
|
性能略低于消息队列RocketMQ。 |
云数据库RDS版 | 适合单纯的数据保存场景。 | 数据直接写入数据库。 | 不涉及 |
时序数据库(TSDB) | 适合根据设备数据进行业务分析和监控的场景。 | 数据直接写入时序数据库。 | 不涉及 |
DataHub | 适合需对数据进行分析处理的场景。 | 数据直接写入DataHub。 | 不涉及 |
表格存储(Tablestore) | 适合单纯的数据存储场景。 | 数据直接写入表格存储实例。 | 不涉及 |
函数计算(Function Compute) | 需要简化设备开发过程,且对设备数据进行一定自由度的处理的场景。 |
|
费用略高。 |
服务端订阅
服务端可以通过AMQP SDK或消息服务(MNS)SDK接收已订阅的产品下所有类型的消息,包含设备上报消息、设备状态变化通知、设备生命周期变更、物模型历史数据上报、OTA升级状态通知、网关发现子设备上报、设备拓扑关系变更等。
使用限制 | 使用注意 | 相关文档 |
---|---|---|
详细的服务端订阅使用限制,请参见服务端订阅使用限制。 |
|
云产品流转到消息队列RocketMQ
通过云产品流转功能,将物联网平台中指定Topic的消息流转到RocketMQ中的Topic,然后通过RocketMQ的SDK接收相应的消息。
- 由于RocketMQ性能突出,推荐通过RocketMQ接收设备消息。
- RocketMQ支持跨租户的Topic授权,可满足一定场景的跨租户的数据流转需求。
使用限制 | 使用注意 | 相关文档 |
---|---|---|
|
|
云产品流转到消息服务(MNS)
可以通过云产品流转功能,将指定Topic的消息流转到MNS的主题中,然后通过MNS的SDK接收相应的消息。MNS对公网环境支持友好。设备消息量不是特别大(<1,000QPS),推荐使用MNS。
使用限制 | 使用注意 | 相关文档 |
---|---|---|
请参见MNS使用限制中,主题相关使用限制。 |
规则引擎在数据流转失败,再重试失败数次后,会丢弃消息。另外,消息类产品存在延迟的可能,业务场景一定要做好消息丢失或者延迟送达的防护。 |
云产品流转到函数计算
通过云产品流转,将指定Topic的消息转入到函数计算中,开发者可以进一步对消息进行处理。函数计算免部署,可以简化业务的开发。
使用限制 | 使用注意 | 相关文档 |
---|---|---|
请参见函数计算使用限制。 |
|
在文档使用中是否遇到以下问题
更多建议
匿名提交