阿里云物联网平台入门训练营:课时2:IoT物模型接入价值与实践(二)
课时2:IoT物模型接入价值与实践(二)
也支持批量创建的能力,我们会提供的一个模板,大家按模板填入这几项信息,按模板的定义把这个设备批样的创建出来。这个模板当前最大支持1万台设备的并发创建,应该是基本满足现在所有客户的一个需求。
第二阶段就是设备开发调试的功能。设备开发调试也是基于标准的数据格式,包括协议。封装了不同语言的SDK 降低并且提供了一些通用的方法。比如设备的注册,设备的初始化、属性上报,事件的上报都有通用的方法来支持。所以并不需要感知数据上面的一些格式。,它全是按标准a link 协议的格式进行上报的。这里写了一个简单的例子,用起来也相对于比较简单。
private void reportpropertyData(){ Map<String,ValueWrapper>properties=newHashMape<String,ValueWrapper>(); properties.put("BatteryLeve",new ValueWrapper,IntValueWrapper(valueParam: 22)); properties.put("C02Value",new ValueWrapper.IntValueWrapper( valueParam: 33)); properties.put("SmokeState",new ValueWrapper.IntValuewrapper( valueParam: 2)); LinkKit,getInstance().getDeviceThing().thingPropertyPost(properties, new IPublishResourceListener(){ @Override public void onSuccess(String s, 0bject o) { System,out.println("=amsmSmokeAlarm, thingPropertyPost succesSamamaa="); @Override public void onError(String s,AError aError) { System.out.println("mmmsmSmokeAlarm,thingPropertyPost errormmmmmmm"); } }); LinkKit.getInstance().registerOnNotifyListener(new IConnectNotifyListener(){ @Override Public void onNotify(Strings,String s1,AMessage aMessage) { System.out.println("==mSmokeAlarm PROPERTY REPLYm=="); System.out.println("TOPIC:" + s1); } @Override public boolean shouldHandle(String s, String s1) { return false: } @Override public void onConnectStateChange(String s, ConnectState connectState) { } }): }
刚刚拷贝的那个产品里边有三个物模型属性的定义。,这个是把三个物模型的属性定identifier 标识符写在这里,同时给它进行赋值。只要调用这个property post 的方法,就会把这三个属性全部上报进来。首先上报上来的基础就是后边也会提供GDK的demo 的一个文件。这个文件里边还是前置需要你完成一些配置,这个配置的信息主要是包括设备的三元组的信息。你只要配置正确之后,就可以把这个设备按这种属性进行上报。所以这个地方有一个特别需要注意的点,就是上报的属性的功能定义必须是物模型已经提前定义好的,必须跟物模型定义里边保持一致。因为这里是封装了一个属于上报的服务,如果你需要自己去开发对应上报的能力的话,定义的topic 必须跟物模型的topic 也保持一致。这个代码运行之后,会看到在物联网控制台里边,在设备下面可以看到有物模型数据的模块,这个运行状态下就可以查询的到刚刚上报的数据。像电池的电量,就是刚刚的上报的第一个属性,同时还有二氧化碳的浓度,这个地方也是可以在控制台上进行查询的。同时在控制台上提供了设备在线调试的能力。在线调试是想以这种设备服务调用的方式来介绍这个在线调试的一个功能,并且根据日志服务来定位当前的一些错误。这个地方如果用标准的SDK 的话,这个SDK 是java 版本的。所以这个地方SDK 实现监听服务的处理器也非常简单。
private void registerserviceHandler(]{ ListeService> srviceList = LinkKit.getInstance[).getDeviceThing().getServices(); far lint 1 = 0: srwicelist != null M 1 < srvicelist.sizel]: i++) { Service service = srvicelist.get(i); LinkKit,getInstance().getDeviceThingl),set5ervicefandler(service.getIdentifier[], new ITResRequestHandterl)[]{ @override public woid onProcess[5tring identify, 0bject result, ITResResponseCallback itResResponseCallback){ System.out.println("receive service invoke,identify-" + identify); if ("VersionUp".equals(identify)) { ImgutParans nputs = (InputParars]resutt; Map<String,ValueWrapper>inputParas=[MapeString,Valuerapper>)inputs.getData(); Syster,out.printIn("Versionup,inputparans=" + JSON,toJSOWString(inputParams}}; //设备服务调用处理逻辅 OutputParams outputparats = mew OutputParars(); outputParams.put("success",new Valuerapper.StringValuelrapper(walue?ar: "true")); itResRespomseCallback,anCompletelidentify, errorlefo null,autputparams); return; } } @override public woid on5uccess[Object o,OutputParams cutputParams) { ALog.d(TAG, mig: "onSuccess[]called with: 0 = ["+ o + "], outputparams = [" + outputparars + "]"); } @override public vold onFail(Cbject o, ErrorInfe errorInfol ){ ALog.d(TAG, msg: "onFail() called with: o =["+o+ "], errorInfo = [" + errorInfo + "]"); } }}; }
这个地方首先是把所有的服务先查询出来,查询到了之后,来轮询的注册服务监听器,这里是注册了一个watch up 的服务监听器。首先是这里会收到一个服务调用的一输入的一参数。这个地方只是简单把它输入出来,如果在做设备开发的时候,这个中间的就是预留出来的一些需要实现的逻辑,这个地方简单的就写了一个回执。刚刚有一点就是在模型定义的时候,是没有把success 这个字段定义在物模型里面去的。
但是服务调用的时候,这个服务端这样实现代码的话,如果调用成功会返回一个success=true 的字段回来,这个设备端的编码完成了后,就可以建立本地启动注册设备,建立连接就可以来监听北向的服务调用的请求。在线调试就是提供设备调试的功能。这个地方就是描述北向模拟北向服务调用的一个能力,可以看一下提前定义的物模型。
这个模型wash up的服务里边,它定义的一个UR,之后没有success字段的,之后用设备瞄准器功能调取一个UR参数,下边有一个按钮发起服务调用。服务调用的时候会产生一个报错,描述reply的时候信息里边多了一个success 字段,这个success 字段因为方法定义的数据标识不存在,所以这个地方日志服务里面就报错,后边就把success字段添加完了之后可以看一下,它只是个字符串类型。然后把字标识符创建完了之后又重新发起在线调试的能力,这个日志调试完了之后就代表物模型服务调用的服务已经处理成功,数据已经写入到平台里边。同样如果服务写入以后,在进行数据和服务调用可以进行查看。可以看到这个地方它的输入参数是什么,这个地方都会展示给预估用户。
四、设备运行和数据应用
下一阶段讲一下设备运行平台的处理的一个流程,物模型平台做了模型数据沉淀,平台了之后开发了相对应的一些衔接产品。只要使用物模型进行开发,使用标准的物模型数据上云数据都可以跟相关的一些物联网产品进行无缝的对接,就可以集成进来。
首先看属性事件服务上报的数据。主要是经历了数据处理的一个流程,主要包括数据加工,数据加工里边刚刚讲到了有一些增值的服务,还有脚本数据转换的服务。如果是自定义的协议的话,会转换成这种a link 协议,同时数字孪生里面还增加了数据映射的功能。就是采集设备跟实际云上建模的设备可以不是相同的一个设备。通过这种建模,通过这种数据映射,可以把采集的数据映射到实际的任意的物模型节点上去,同时还提供了增值的服务。
增值的服务就包括物模型级别的一个校验,数字孪生里边也提供了规则的运算跟时序数据的分析。数据存储这一块会把用户上报的全量数据,还有复合物模型规范的数据,时序的数据都会存储下来,以备各方面的需要都可以,并且下边是提供了一些相应的接口,这个接口列表会比这个更加详细,后边我会有一个附录来来链接到北向的API,可以针对自己的一些业务场景,任君自取了。还有一些使用方式还支持这种异步消息的流转,只要按规范实现订阅了之后,文物模型的数据都会流转到服务端,进行后续的数据处理。刚刚讲的比较多的就是设备上下行的一些topic,像属性事件上报的一些topic,事件的topic 一会讲,属性上报的一些topic大家已经看到了,同时还提供了无模型TSR的描述模板的查询能力。然后存出来的数据之后,我们会跟相关的一些产品进行分子对接。比方studio 来进行北向的手机APP 应用开发,可以直接把数据进行查询到在它的设备管理应用里面进行展示。同时还提供数据分析的能力,数据分析的能力后边也是在本次训练营里边有课程的安排,大家后边可以注意听一下。
五、接入实践
第三部分是讲一下复杂设备的接入的物模型的使用流程。复杂设备主要是介绍模块的能力。
因为是一个复杂的设备,复杂的设主要的特点就是它的功能定义特别多。在使用场景里面,比方工业场景尤为明显,比如车床或者是大型的纺纱机这种设备,它的是属性点位数或者是功能定义有超过一千多。所以就提供了一个模块的功能,模块功能这里以一个简单的例子来简单说明一下实际使用步骤,所以物模型相对比较简单,有什么问题的话可以针对性的问一下,我们来讨论一下。这里是以这种灯暖型浴霸作为一个例子,为每个取暖灯都新增一个功能模块,描述一个浴霸的时候,我认为它主要是有一个中央控制的模块,还有四个取暖灯都是不同的模块。通过中央控制的模块,实现对每个取暖灯进行不同的数据上报,或者是设备的控制。所以就每个取暖灯都定一个单独的模块。这里会定义一个温度过温度过高的告警事件定义在这里。这里主要是来讲一下事件的使用方式,还有事件在使用过程中怎么跟SDK进行集成,定义之后,属性上报协议跟刚刚讲到的事件上报属性上报的实现方式有点类似。
public void thingEventPost() ( MqttPublishRequest request = new MgttPublishRequest(); String eventIdentifier ="heatingLamp_1:highTempWarning"; request,topic="/sys/"+productKey+"/"+deviceName+"/thing/event/"+eventIdentifier+"/post"; request.replyTopic = request,topic + "_reply"; request.isRPC = true; request.qos = 0; request.payload0bj="(\"d\":202108091200001,"params\":(\"temperature\":99.82))"; LinkKit.getInstance().publish(request new IConnectSendListener() { @override public void onResponse(ARequest aRequest,AResponse aResponse) { ALog.d(TAG, msg:"onResponse:" + (aResponse == null ? "m :aResponse.data)); } @0verride public void onFailure(ARequest aRequest,AError aError){ ALog.d(TAG,msg:"onFailure:" + (aError == null ? ‘’’’ : (arror.getCode() + aError.getMsg()))); } }); }