MQTT接入阿里云IoT平台应用案例MQTT接入阿里云IoT平台 前言:此文档旨在介绍阿里云IoT平台配置MQTT的方式方法,从而可以使用蓝蜂MQTT网关将下位机数据传输到阿里云IoT平台。按照如下步骤就可以成功实现数据上云的功能。 一、配置阿里云IoT平台 1.1登录 进入阿里云IoT平台官网(https://www.aliyun.com/),登录账号,然后点击右上角控制台。 进入控制台后,选择【产品与服务】→【物联网平台】。或直接搜索“物联网平台”。 注:第一次使用阿里云 IoT 平台物联网服务器需要先开通服务才能使用,跟随界面提示点击即可。 这样便可进入物联网平台。 1.2创建产品 点击实例,可进入实例详情,点击【设备管理】-【产品】-【创建产品】,如图 【产品名称】:自定义 【所属品类】:选择标准品类时,可选择与自己产品设备相近的模型,选择后系统可自动为您创建必选功能,也可根据需要添加可选功能和自定义功能,本文档选择自定义品类,自定义功能 【节点类型】:选择直连设备 【联网方式】:蜂窝(2G/3G/4G/5G) 【数据格式】:ICA标准数据格式(Alink JSON) 【校验类型】和【认证方式】可保持默认 1.3添加设备 创建产品完成后,点击【确认】按钮后,可进行添加设备,点击【前往添加】。 【DeviceName】:设备名称DeviceName建议填写蓝蜂网关sn编号,可方便后续对配置文件进行导入导出操作,本示例填写的为网关sn编号200121091367。 点击【确认】按钮,添加完成,可在设备列表中看到添加的设备。 点击【查看】按钮,可查看设备的连接参数以及其他详细信息 可以看到我们创建的设备的三元组,如图 1.4配置阿里云IoT平台物模型 在阿里云IoT平台,点击【产品】,找到我们创建的产品,点击【查看】按钮,如图 进入产品中,点击【功能定义】-【编辑草稿】 进入编辑草稿页面,点击【添加自定义功能】,这里我们添加属性,添加温度,湿度和开关三个属性,您可根据自己需求进行填写,如图 注意:数据类型需要根据设备每个属性的实际情况进行选择,在后面使用蓝蜂MQTT网关配置工具配置时,需要与之进行匹配。 区别于EMCP物联网云平台,此处不需要填写变量的地址,数据是根据“标识符”来展示的。建议在创建变量后将创建的“变量名称”、“标识符”、“数据类型”记录下来,如下表。在之后的蓝蜂MQTT网关配置工具中会用到。
添加完成后,列表中可看到我们添加的3个属性,点击左下角【发布上线】: 注: 1、如果想要修改创建好的功能类型,点击编辑草稿即可。 2、如果想要创建新的模块(类似于变量的分组)点击编辑草稿→添加模块即可。 至此,按照如上步骤,对于阿里云平台的设置就完成了,下面我们进行连接设置。 二、配置蓝蜂MQTT网关配置工具 将网关通电联网,使用电脑与网关232串口连接,使用本地串口配置方式登录进入蓝蜂MQTT网关配置工具,详细配置工具使用说明请参考《蓝蜂MQTT网关配置工具使用说明》 2.1登录 打开“蓝蜂MQTT网关配置工具”,此处必须使用本地串口配置的方式进行配置,如图: 使用232串口,将网关的RS232口使用USB转232线接到电脑串口上,同时填写配置参数,包括选择通讯口,波特率,数据位,数据校验,停止位。默认参数为115200,8,无,1。 【通讯口】:选择正确的串口号,可在电脑的“设备管理器”中查看。本机为COM4。 【读取网关串口参数】:如果对于串口参数并不了解,可点击“读取网关串口参数”按钮,客户端会主动搜索并填入已选中的串口的参数。前提是必须选择正确的通讯口。 【记住配置】:点击“记住配置”按钮后,会记住当前配置,避免每次进入时需要重新配置的问题,再次进入时可直接进行连接操作。 点击“立即连接”按钮,稍等片刻即可进入网关配置工具进行配置。 2.2连接阿里云IoT平台 进入蓝蜂配置工具后,点击【MQTT连接】-【MQTT连接配置】,可用于配置连接的MQTT服务器的参数。配置完成后,网关即可连接MQTT服务器 对于连接阿里云服务器的参数,可在阿里云IoT平台查找,点击【设备】按钮,可在阿里云IoT平台找到上述创建的设备,如图 点击设备后面的【查看】按钮,可找到连接参数,如图 将弹窗中的参数分别粘贴填写到蓝蜂MQTT网关配置工具的连接配置页面,如图 其他参数默认填写 注意:将连接参数从阿里云IoT平台粘贴填写到蓝蜂MQTT网关配置工具时,参数前面和后面不要留有空格,否则将无法连接阿里云IoT平台。 填写完成,点击【保存】按钮,需要重启网关,配置才会生效,可正确接入阿里云IoT平台,连接成功后,可在阿里云IoT平台看到设备已正常在线 2.3添加驱动、变量 在驱动管理页面为网关添加驱动,可按照自身设备进行填写,如图,详细添加驱动使用说明请参考《蓝蜂MQTT网关配置工具使用说明》。 添加驱动完成后,可为设备添加需要采集的变量参数,可添加上我们在阿里云IoT平台添加的3个参数,在阿里云IoT平台找到我们配置发布的3个参数,如图 进入产品后,点击【功能定义】,可在里面看到我们创建的3个属性,如图 我们依次将3个参数添加到蓝蜂MQTT网关配置工具的变量管理中 添加完成后,如图 注意:蓝蜂MQTT配置工具中的变量标识必须与阿里云IoT平台的属性标识符保持一致且大小写一致,这样阿里云IoT平台才会正确解析物模型。 注: 网关会将创建的所有变量上传到阿里云IoT平台,由IoT平台根据标识符来判断数据是否采集、展示。 三、上报数据 3.1上报数据配置 要想实现设备上报数据到阿里云IoT平台,我们需要先在蓝蜂MQTT网关配置工具中进行上报数据配置 点击【数据传输配置】-【数据上报配置】,我们可在数据上报配置中设置上报主题 对于上报主题我们需要在阿里云IoT平台打开对应设备的topic列表找到属性上报topic,如图 进入产品后,点击【topic类列表】-【物模型通信topic】,即找到属性上报主题,如图 主题中的通配符${deviceName}需要替换成我们这个产品中创建的设备的三元组中的DeviceName。 我们的示例在阿里云IoT平台创建的设备的DeviceName为网关sn编号200121091367,而在蓝蜂配置工具中可使用通配符${sn}代替200121091367。 因此我们的上报主题为/sys/gqbaihhDlTb/${sn}/thing/event/property/post,我们将该主题写入数据上报配置中的上报主题中,如图 【上报方式】:可按需求填写,此处我们选择定时上报 ※【加工脚本】如下,复制粘贴即可,一般不需要进行修改: function reportToJson(signalArray, system){ var json ={ id: system.msgId, version:"1.0", sys:{ ack : 0}, method: "thing.event.property.post", params:{} } var time = new Date().getTime(); for(var i=0; i<signalArray.length; i++){ var signal = signalArray[i]; json.params[signal.key] = { time:time, value:Number(signal.value) } } return JSON.stringify(json); } 点击【确定】按钮,配置完成,配置完成后,将网关重启,并将网关接入设备后,采集到的数据就可上报到阿里云IoT平台了。 3.2查看数据 当设备采集到数据并上报到阿里云IoT平台后,我们可以在阿里云IoT平台,点击【设备】,找到我们接入的设备 点击【查看】按钮,进入设备详情中,点击【物模型数据】,便可查看到我们采集到的数据,如图 点击【查看数据】按钮,可查看该属性的历史数据详情,如图 四、写入数据 4.1写数据配置 从阿里云IoT平台向设备写入数据,需要在蓝蜂MQTT网关配置工具中对写入进行配置 点击【数据传输配置】-【写变量配置】,我们可在写变量配置中设置请求和响应主题 对于请求和响应主题我们可以在阿里云IoT平台打开对应设备的topic列表找到属性设置topic,如图 进入产品后,点击【topic类列表】-【物模型通信topic】,即找到属性设置主题,如图 主题中的通配符${deviceName}需要替换成我们这个产品中创建的设备的三元组中的DeviceName。 我们的示例在阿里云IoT平台创建的设备的DeviceName为网关sn编号200121091367,而在蓝蜂配置工具中可使用通配符${sn}代替200121091367。 因此我们的请求主题为:/sys/gqbaihhDlTb/${sn}/thing/service/property/set, 响应主题为:/sys/gqbaihhDlTb/${sn}/thing/service/property/set_reply 我们将请求主题和响应主题写入写变量配置中的请求和响应主题中,如图 ※【请求解析脚本】如下,复制粘贴即可,一般不需要进行修改: function writeReqToJson(str){ if(str!=""){ var req = JSON.parse(str) var keys = Object.keys(req.params) var key = keys[0] var msgId = req.id var json = { key: key, value:req.params[key]+"",msgId:msgId} return JSON.stringify(json) } return {} } ※【响应加工脚本】如下,复制粘贴即可,一般不需要进行修改: function writeRespToJson(signal, system){ var json = { "code": 200, "data": {}, "id": system.msgId, "message": "success", "version": "1.0" } return JSON.stringify(json) } 点击确定按钮,配置完成,配置完成后,将网关重启,并将网关接入设备后,就可以从阿里云IoT平台直接控制设备进行写入数据了。 4.2向设备写入数据 打开阿里云IoT平台,点击【监控运维】-【在线调试】,选择我们想要写入数据的设备,如图 找到想要写入数值的属性,我们此处对温度进行写入数值36,如图 设置成功后,数值便写入成功了,在阿里云IoT平台数值查看处我们也可以看到我们写入成功的数据,如图 注意: 点击“获取”时,获取到的值是阿里云平台最后一次成功通讯的值。即使获取成功,也不能说明网关和下位机通讯正常。 五、注意事项 1、LF220网关暂时不支持web配置页,目前暂时不能设置交换机和路由器模式。 2、在打开蓝蜂MQTT网关配置工具之后,请勿关闭已打开的命令行窗口,或修改浏览器内地址,否则将无法正常使用配置工具。 3、连接阿里云IoT平台时建议将网关的“透传设置”、“采集异常设置”、“状态上报设置”关闭。 4、配置成阿里云服务器以后,再次配置网关时只能使用RS232转USB本地配置,不能使用在线配置。 5、配置LF220网关参数时必须要和阿里云服务器中设置的一致。 6、阿里云服务器(或其他服务器)有自己固定的格式,需要编写对应的脚本。阿里云服务器脚本按照文档中填写的即可,可以直接复制粘贴。 7、如果串口232是7位时,串口连接点击升级,升级成功客户端不会提示升级成功,但是网关实际会升级成功。 8、蓝蜂MQTT网关配置工具的网关编码格式为UTF-8。 9、兼容性:win7, win10, win11系统,不支持winxp及更低版本windows系统,不支持linux、MacOS、android和ios系统。 河北蓝蜂信息科技有限公司 公司电话:0311-68025711 技术支持:400-808-6168官方网站:www.lanfengkeji.com
文章分类:
应用案例
|
|