计算
弹性云服务器 ECS
Flexus云服务
裸金属服务器 BMS
弹性伸缩 AS
镜像服务 IMS
专属主机 DeH
函数工作流 FunctionGraph
云手机服务器 CPH
Huawei Cloud EulerOS
网络
虚拟私有云 VPC
弹性公网IP EIP
虚拟专用网络 VPN
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
VPC终端节点 VPCEP
云连接 CC
企业路由器 ER
企业交换机 ESW
全球加速 GA
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
边缘安全 EdgeSec
威胁检测服务 MTD
CDN与智能边缘
内容分发网络 CDN
CloudPond云服务
智能边缘云 IEC
迁移
主机迁移服务 SMS
对象存储迁移服务 OMS
云数据迁移 CDM
迁移中心 MGC
大数据
MapReduce服务 MRS
数据湖探索 DLI
表格存储服务 CloudTable
云搜索服务 CSS
数据接入服务 DIS
数据仓库服务 GaussDB(DWS)
数据治理中心 DataArts Studio
数据可视化 DLV
数据湖工厂 DLF
湖仓构建 LakeFormation
企业应用
云桌面 Workspace
应用与数据集成平台 ROMA Connect
云解析服务 DNS
专属云
专属计算集群 DCC
IoT物联网
IoT物联网
设备接入 IoTDA
智能边缘平台 IEF
用户服务
账号中心
费用中心
成本中心
资源中心
企业管理
工单管理
国际站常见问题
ICP备案
我的凭证
支持计划
客户运营能力
合作伙伴支持计划
专业服务
区块链
区块链服务 BCS
Web3节点引擎服务 NES
解决方案
SAP
高性能计算 HPC
视频
视频直播 Live
视频点播 VOD
媒体处理 MPC
实时音视频 SparkRTC
数字内容生产线 MetaStudio
存储
对象存储服务 OBS
云硬盘 EVS
云备份 CBR
存储容灾服务 SDRS
高性能弹性文件服务 SFS Turbo
弹性文件服务 SFS
云硬盘备份 VBS
云服务器备份 CSBS
数据快递服务 DES
专属分布式存储服务 DSS
容器
云容器引擎 CCE
容器镜像服务 SWR
应用服务网格 ASM
华为云UCS
云容器实例 CCI
管理与监管
云监控服务 CES
统一身份认证服务 IAM
资源编排服务 RFS
云审计服务 CTS
标签管理服务 TMS
云日志服务 LTS
配置审计 Config
资源访问管理 RAM
消息通知服务 SMN
应用运维管理 AOM
应用性能管理 APM
组织 Organizations
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
应用身份管理服务 OneAccess
数据库
云数据库 RDS
文档数据库服务 DDS
数据管理服务 DAS
数据复制服务 DRS
云数据库 GeminiDB
云数据库 GaussDB
分布式数据库中间件 DDM
数据库和应用迁移 UGO
云数据库 TaurusDB
人工智能
人脸识别服务 FRS
图引擎服务 GES
图像识别 Image
内容审核 Moderation
文字识别 OCR
AI开发平台ModelArts
图像搜索 ImageSearch
对话机器人服务 CBS
华为HiLens
视频智能分析服务 VIAS
语音交互服务 SIS
应用中间件
分布式缓存服务 DCS
API网关 APIG
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
多活高可用服务 MAS
事件网格 EG
企业协同
华为云会议 Meeting
云通信
消息&短信 MSGSMS
云生态
合作伙伴中心
云商店
开发者工具
SDK开发指南
API签名指南
Terraform
华为云命令行工具服务 KooCLI
其他
产品价格详情
系统权限
管理控制台
客户关联华为云合作伙伴须知
消息中心
公共问题
开发与运维
应用管理与运维平台 ServiceStage
软件开发生产线 CodeArts
需求管理 CodeArts Req
部署 CodeArts Deploy
性能测试 CodeArts PerfTest
编译构建 CodeArts Build
流水线 CodeArts Pipeline
制品仓库 CodeArts Artifact
测试计划 CodeArts TestPlan
代码检查 CodeArts Check
代码托管 CodeArts Repo
云应用引擎 CAE
开天aPaaS
云消息服务 KooMessage
云手机服务 KooPhone
云空间服务 KooDrive

端侧规则

更新时间:2024-11-26 GMT+08:00

概述

云端规则中,用户创建的规则的解析及执行均在云端完成,云平台需要判断条件是否满足并触发相应的设备联动操作。端侧规则是指用户在云平台创建的设备联动规则,可以下发到端侧设备,该设备上会运行端侧规则引擎,对云端下发的规则进行解析并执行。端侧规则可以在网络中断或设备无法与云端交互情况下,继续在端侧执行指定规则。端侧规则可以扩展用户应用场景,提升端侧设备运行的稳定性及执行效率等。例如:设置室内光照强度低于20时,打开灯控总开关,自动照明,实现不依赖网络设备的智能控制。

图1 端侧规则架构图

相关背景概念说明可参考基础概念

使用场景

公路隧道中的监控设备种类较多,数量较大,并且隧道内网络环境复杂,网络质量也不稳定。然而,在应急处理时对网络实时性要求较高,因此无法将应急设备间的联动完全依赖于云端规则处理,需要借助端侧规则引擎实现预案联动。在实施时,可以预先针对火灾、交通事故等不同情况制定相应的设备联动预案。监控人员可以根据隧道内发生的情况,一键启动设备预案,通过端侧规则引擎实现多种相关设备同步进行状态变化,从而降低对网络质量的依赖,提高整体设备联动效率。例如,当烟道温度过高时,可以联动排水阀控制器打开排水阀实现降温;当一氧化碳浓度过高时,可以联动covi设备控制风机来通风。

使用限制

  • 相对云端规则,目前端侧规则的执行动作只支持命令下发。
  • 设备需适配指定的SDK:Device SDK C_v1.1.2及以上版本。
  • 设备需通过上述SDK提供的API,主动上报SDK版本号至华为云IoT平台。

使用说明与示例

下面以智能路灯系统为例,介绍如何使用端侧规则。

  1. 访问设备接入服务,单击“管理控制台”进入设备接入控制台。选择您的实例,单击实例卡片进入。
  2. 创建产品以及新增物模型。

    1. 创建产品,进入管理控制台,选择您的实例,单击实例卡片进入。选择“产品-创建产品”,单击“设备类型”,在弹出的对话框内选择“智能路灯”,填写好产品名称后单击“确定”。
      图2 创建产品-SmartLight
    2. 创建模型,右侧选择“产品”,找到“SmartLight”,然后单击“详情”。
      图3 产品-查看SmartLight详情
    3. 进入产品信息页面后,单击“导入库模型”,选择“SmartStreetLight”,然后单击“确定”。
      图4 产品-导入库模型SmartStreetLight
    4. 单击“基本信息”,可见模型定义中包含两个服务,分别为“BasicData”和“LightControl”,单击“BasicData”可见服务详情中包含一个名为“luminance”的属性。单击“LightControl”可见其包含一个名为“switch”的命令。
      图5 模型定义-SmartLight

  3. 在左侧选择“设备-所有设备”,单击“注册设备”。选择步骤2创建产品选择的资源空间以及所属产品,填写设备标识码,单击“确定”。

    图6 设备-注册密钥设备

  4. 设备创建成功,复制设备密钥,此处需要保存好设备密钥,后面需要用到。

    图7 设备-注册设备成功

  5. 创建规则。

    1. 在左侧选择“规则-设备联动”,单击上方"所属资源空间",选择设备所在产品的所属资源空间,然后单击“创建规则”。
      图8 设备联动-创建规则
    2. 进入创建规则的页面,填写规则名称,选中“端侧执行”,然后选择规则执行设备,即选择将此条规则下发给哪个设备去解析执行。
      图9 新建联动规则-端侧规则基本信息
    3. 选择刚刚创建的设备“smartlight001”,选好后,单击右下角按钮“确定”。
      图10 新建联动规则-选择端侧设备
      说明:

      只有适配了端侧SDK的设备(目前只支持Device SDK C_v1.1.2版本),才支持创建端侧规则。

    4. 单击“添加条件”,可见设备为本设备不可选择;单击“添加动作”,用户可根据需求选择指定设备,该设备可以为本设备,也可以为其他设备。
      图11 新建联动规则-条件及动作说明
    5. 在触发条件中配置属性触发为“luminance<= 27”,在执行动作中配置control_light指令并填写参数值,light_state为“on”。
      图12 新建联动规则-条件及动作

  6. 参考下表参数说明,创建设备联动规则。

    表1 参数说明

    参数名称

    说明

    规则名称

    创建的规则名称。

    激活规则

    勾选:创建规则后,规则处于激活状态。

    不勾选:创建规则后,规则处于未激活状态。

    生效时间

    • 一直生效:没有时间限制,持续检查是否满足当前规则条件。
    • 指定时间:可以选择时间段,在特定的时间内检查是否满足规则条件。
      说明:

      由于端侧规则存储在内存当中,当设备下电时,端侧存储的规则将清空。当设备重新开机或上电时,端侧设备会从云端更新该设备的历史全量规则。

    描述

    对该规则的描述。

    触发条件

    满足条件:可设置满足全部条件,或者任意一个条件。

    说明:

    当设置满足全部条件时,不能同时设置设备属性触发和定时触发,只支持同时设置多种设备属性触发。

    触发类型:目前只支持设备属性触发和定时触发。

    • 设备属性触发:设备上报属性时触发。
      • 选择服务:选择对应的服务类型。
      • 选择属性:选择满足条件后上报数据的设备属性。
      说明:
      • 属性的数据类型为int和decimal时,支持选择多种判断符号。
      • 属性的数据类型为string时,判断条件仅支持相等。
    • 定时触发:设置个性化的定时条件,如每日定时触发或按策略定时触发。
      • 每日定时触发:可以设置规则触发的时间点,该条件一般用于周期性的触发条件,如每天7:00,关闭路灯。
      • 按策略定时触发
        • 时间点:可以选择规则触发的起始时间点。
        • 重复次数:规则重复触发的次数(1~1440次)。
        • 间隔(分钟):在起始时间点后,重复触发规则的时间间隔(1~1440分钟)。

    执行动作

    单击“添加动作”,设置在规则触发后,需要执行的动作。

    下发命令:依次选择需要执行下发命令的设备、服务、命令,然后配置下发命令的参数。

  7. 单击右下角“创建规则”,完成端侧规则的创建。新创建的规则默认激活,用户可以在规则列表“状态”列禁用规则。
  8. 编写设备侧代码。在支持端侧规则引擎的SDK中(目前仅支持Device C SDK),只需要用户实现属性上报及命令处理的回调函数即可。单击这里获取iot-device-sdk-c,按说明文档步骤操作,在准备工作完成之后进行以下修改:

    1. 打开文件src/device_demo/device_demo.c,找到函数HandleCommandRequest。
      图13 命令处理

      此处为方便示例,将上述命令处理实现为:

          printf("----- execute command----- \n");
          printf("service_id: %s\n", command->service_id);
          printf("command_name: %s\n", command->command_name);
          printf("paras: %s\n", command->paras);
    2. 打开文件src/device_demo/device_demo.c,找到函数TestPropertiesReport。
      图14 代码替换

      替换代码为:

      const int serviceNum = 1; // reported services' total count
      ST_IOTA_SERVICE_DATA_INFO services[serviceNum];
      
      #define MAX_BUFFER_LEN 70
      char propsBuffer[MAX_BUFFER_LEN];
      //此处为获取温度值的示例,从真实传感器获取数值需要由用户实现
      if(sprintf_s(propsBuffer, sizeof(propsBuffer), "{\"luminance\": %d}", 20) == -1){
      printf("can't create string of properties\n");
      return;
      }
      
      services[0].event_time = GetEventTimesStamp(); // if event_time is set to NULL, the time will be the iot-platform's time.
      services[0].service_id = "BasicData";
      services[0].properties = propsBuffer;
      
      int messageId = IOTA_PropertiesReport(services, serviceNum, 0, NULL);
      if (messageId != 0) {
      printf("report properties failed, messageId %d\n", messageId);
      }
      free(services[0].event_time);
    3. 编译sdk并执行。观察输出,可以看到对应的command。
      ----- execute command-----
      service_id: BasicData
      command_name: control_light
      paras: {
              "light_state":       "on"
      }

      以上日志仅为一个示例。用户需要实现上述1中具体的命令处理代码。

      跨设备执行命令时,需要设备间具备相互通信的能力。同时由于用户使用的通信协议可能不同,如WiFi,BLE,ZigBee等,所以要调用函数IOTA_SetDeviceRuleSendMsgCallback注册自定义发送函数。

      Demo中已默认注册HandleDeviceRuleSendMsg,用户需要自行在预置函数HandleDeviceRuleSendMsg实现消息发送。执行命令的设备接收消息后,则需要自行实现命令解析和执行。

      图15 解析命令并执行

我们使用cookie来确保您的高速浏览体验。继续浏览本站,即表示您同意我们使用cookie。 详情

文档反馈

文档反馈

意见反馈

0/500

标记内容

同时提交标记内容