通过Node-Red将西门子PLC数据上传至阿里云物联网平台并进行可视化显示

本文主要是介绍通过Node-Red将西门子PLC数据上传至阿里云物联网平台并进行可视化显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇基于我之前的文章《利用Node-Red读写西门子PLC并将数据上传至云服务器》,Node-Red搭建及读写PLC部分请参考该文章。

首先在阿里云物联网平台开通公共实例,开通成功后在公共实例的设备管理-产品处点击创建产品。

产品名称可随意填写,所属品类选择自定义品类,节点类型选择直连设备,联网方式根据自己设备的实际情况选择,数据格式本文选择的是ICA标准数据格式,其它地方无需更改,点击确认完成创建。

点击创建完成的产品,进入Topic类列表的物理模型Topic,记下最前面设备属性上报的Topic类内容。

/sys/gwaeIrxRg81/${deviceName}/thing/event/property/post

点击Topic类列表右侧功能定义,点击编辑草稿并添加自定义功能,此处CPU温度是我随便填写的。

到设备管理-设备处添加设备,产品选择之前创建的产品,DeviceName和备注名称可自己定义,之后点击确认完成创建。

在设备界面点击进入已经创建完的设备,在设备信息下方有一个MQTT连接参数,点击查看,记下里面的所有内容。

本地PC或树莓派启动Node-Red,在浏览器输入 http://127.0.0.1:1880/ 访问Node-Red界面。

在网络处拖出MQTT OUT节点,双击该节点进入编辑,点击服务端右侧的笔新建一个服务端,服务端名称可自定义。

连接处的服务端填写之前从阿里云获取的MQTT连接参数的 mqttHostUrl,端口填 1883 ,

客户端ID填从阿里云获取的MQTT连接参数的 clientId

安全处的用户名填写从阿里云获取的MQTT连接参数的 username

密码填写从阿里云获取的MQTT连接参数的 passwd

其它内容保持不变,点击右上角添加完成创建。

在MQTT OUT节点的服务端处选择刚才创建的服务端,主题处填写从阿里云获取的设备属性上报的Topic类内容,并将${deviceName}更改为阿里云上创建的设备的名称,点击完成。

按照我之前的文章配置S7  in节点,本篇只用到了PLC DB1块的Int数据。

因阿里云物联网设备属性上报有固定格式,故此时不能直接将S7 in和MQTT OUT节点直接相连,具体请参考该文章。

在界面左侧功能处拖出template节点,双击该节点在模板处填入如下格式,其中 payload.Int 为从前一个S7  in节点处获取的数据,输出为选择JSON后点击完成。

{"params": {"Int": {{payload.Int}}}
}

将各节点按照下图所示连接,可使用debug节点获取从template节点处流出的数据,查看是否正确。

在PLC处创建相关DB块,取消勾选优化块的访问并编译,并在PLC属性处勾选允许来自远程对象的 PUT/GET通信访问,将程序下载入PLC。

 

回到Node-Red界面,点击右上角部署,若配置正确 debug 节点会输出Int数据,且MQTT OUT节点会显示已连接,此时打开阿里云物联网平台,在监控运维-日志服务,选择之前创建的设备,可以看到Node-Red向阿里云发出的数据。

进入阿里云Iot Studio,在项目管理处新建项目并填写项目名称,进入创建好的项目,在产品处点击关联物联网平台产品,在设备处点击关联物联网平台设备。

 

 

回到应用开发在Web应用处选择新建,填入应用名称并选择刚才创建的项目,点击确定完成创建,在组件处找到仪表盘并拖出,点击仪表盘,在右侧展示数据处点击配置数据源,选择之前创建好的产品以及设备和CPU温度属性,点击确定完成创建,此时可发现仪表盘的示数发生变化。

可视化基本完成,更多功能可自己探索,点击右上角发布即可发布界面。

这篇关于通过Node-Red将西门子PLC数据上传至阿里云物联网平台并进行可视化显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/471951

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1