您可以设置规则引擎数据流转,将处理后的数据转发到云数据库RDS版(以下简称RDS)的实例中存储。本文以物模型数据上报Topic为例,介绍流转消息数据的完整流程。

前提条件

  • 已创建数据源DataSource,并添加物模型数据上报Topic。具体步骤,请参见添加待流转的数据源
  • 已在您的物联网平台实例所在地域,创建专有网络下的MySQL或SQL Server版RDS实例,并创建数据库和数据表。RDS使用方法,请参见云数据库RDS文档

限制说明

  • 仅支持同地域转发。例如:华东2(上海)的物联网平台实例数据只能转发到华东2(上海)的RDS数据表中。
  • 仅支持转发到专有网络(VPC)下的RDS实例。
  • 支持MySQL实例和SQL Server实例。
  • 支持普通数据库和高权限数据库的转发。
  • 仅支持转发JSON格式数据。

创建数据目的

  1. 登录物联网平台控制台
  2. 在左侧导航栏,选择规则引擎 > 云产品流转
  3. 可选:云产品流转页面,单击右上角体验新版,进入新版功能页面。
    说明 如果您已执行过此操作,再次进入云产品流转页面,会直接进入新版功能页面。
  4. 单击数据目的页签,然后单击创建数据目的
  5. 创建数据目的对话框,输入数据目的名称,例如DataPurpose,按照以下参数说明,完成配置,然后单击确定
    参数 描述
    选择操作 选择存储到云数据库(RDS)中
    地域 固定为您的物联网平台实例所在地域。
    RDS实例 选择RDS实例。
    数据库 输入数据库名。
    说明 如果是高权限数据库,需要您手动输入数据库名称。
    账号 输入RDS实例的用户账号。此账号应具有该数据库的读写权限,否则规则引擎无法将数据写入RDS。
    说明 规则引擎获得账号后,仅将规则匹配的数据写进数据库中,不会做其他操作。
    密码 输入登录RDS实例的密码。
    表名 输入数据库中已建立的数据表名。规则引擎将把数据写入这张表上。
    角色 授权物联网平台将数据写入RDS。

    如您还未创建相关角色,单击创建RAM角色,跳转到RAM控制台,创建角色和授权策略,请参见创建RAM角色

配置并启动解析器

  1. 创建解析器,例如DataParser。具体操作,请参见创建解析器
  2. 解析器详情页面,关联数据源。
    1. 在配置向导的数据源下,单击关联数据源
    2. 在弹出的对话框中,单击数据源下拉列表,选择已创建的数据源DataSource,单击确定
  3. 解析器详情页面,关联数据目的。
    1. 单击配置向导的数据目的,然后单击数据目的列表右上方的关联数据目的
    2. 在弹出的对话框中,单击数据目的下拉列表,选择已创建的数据目的DataPurpose,单击确定
    3. 在数据目的列表,查看并保存数据目的ID,例如为1000
      后续解析脚本中,需使用此处的数据目的ID
  4. 解析器详情页面,单击解析器
  5. 在脚本输入框,输入解析脚本。脚本编辑方法,请参见脚本示例
    函数参数说明,请参见函数列表
    //通过payload函数,获取设备上报的消息内容,并按照JSON格式转换。
    var data = payload("json"); 
    //筛选出上报的温湿度值。
    var h = data.items.Humidity.value;
    var t = data.items.Temperature.value;
    // RDS表结构为id[自增主键] deviceName、temperature、humidity、time,在writeRds方法中,可以按column:value的形式,将值写入对应的列。
    // 设置温度值大于38时触发规则。
    if (t > 38) { 
        writeRds(1000, {"devcieName":deviceName(), "temperature":t, "time":timestamp(), "humidity":h});  
    }
  6. 单击调试,根据页面提示,选择产品和设备,输入Topic和Payload数据,验证脚本可执行。
    参数示例如下:调试示例

    运行结果如下,表示脚本执行成功。

    调试结果
  7. 单击发布
  8. 回到云产品流转页面的解析器页签,单击解析器DataParser对应的启动按钮,启动解析器。
  9. RDS控制台数据安全性页面,设置和查看白名单。配置完成后,规则引擎为了连接RDS,会在RDS的白名单中添加下列IP。若以下IP未出现,请手动添加。具体操作,请参见云数据库RDS文档
    • 华东2:100.104.53.192/26,100.104.148.64/26,100.104.6.192/26,100.104.143.128/26,100.104.73.128/26,100.104.200.64/26,100.104.40.64/26
    • 亚太东南1(新加坡):100.104.106.0/24
    • 美国(硅谷):100.104.8.0/24
    • 美国(弗吉尼亚):100.104.133.64/26
    • 德国(法兰克福):100.104.160.192/26
    • 日本(东京):100.104.160.192/26
    RDS数据库