图数据库(neo4j)在工业控制中的应用

        最近看到国外发表的一篇文章,提到将OPC UA 模型映射到neo4j图模型数据库中,通过GraphQL 访问效率很高,顿时感觉自己眼睛一亮,这是一个好主意。

图模型

        事物的模型中,除了它自身的某些特征之外,还包括它与其它事物的关系特征,例如一个学生的属性包括姓名,性别,年龄等属性,同时,他还有许多关系属性,比如他属于哪一个院系,那个班级,他的同学等等。

正是由于此,我们通常称的工程被定义为:

   系统是由一组实体和这些实体之间的关系所构成的集合。其功能要大于这些实体各自的功能之和。

   构建模型中强调关系的重要性,需要有一种更有效的方法来表达事物之间的关系。这就是图模型。

    图模型忽略每个事物的形状,将它们抽象成为一个“点”,点与点之间的连线描述事物之间的关系。

定义

在图模型中,模型由节点和节点之间的关系构成的。每个节点表示了一个物体的模型。它的内部包括了属性和特征。而关系表示了物件之间的相互关系。

        数学有一个分支叫做《图论》。数学家使用图可以构建事物的模型,并且提出了各种数学方法来研究图模型的规律。 

    工业领域中的OPC UA 信息模型也是基于图模型构建的。基本的节点包括对象,属性和方法,关系被称为reference。

    由此可见,OPCUA 信息模型可以转换成为通用的图模型。

在工程设计中,我们经常使用图模型来描述组件,子系统等事物的关系,例如技术讨论中的白板上绘制各种图:

转换成图模型

所以,也有人称为,图模型是“白板”友好的模型 

图模型的文本表达

结构描述语言都能够描述图模型,常见的有:

  • XML
  • JSON

图模型描述的结构包括了:

  •  节点属性-关系,例如:OPCUA 
  • RDF ,例如:知识图谱的描述

图形数据库

图形数据库是以图形模型特点存储数据的数据库,也被称为“图原生”数据库。

        图形数据库是将数据存储为网络图的 NoSQL 数据库。图形数据库与其他选项的区别在于,它们记录了数据之间的关系并对其进行了优先级排序。

        图形数据库由节点和边组成,其中节点表示特定实体,而边表示两个节点之间的连接。它们被设计为可扩展的,并提供在其他数据库中难以找到的灵活性。

图形数据库与关系数据库

        两者之间最显着的区别是,图形数据库将数据之间的关系存储为数据。关系数据库以不同的方式推断出对数据之间关系的关注点。关系焦点在数据表的列之间,而不是数据点之间。

        这两个数据库都使添加新数据变得容易。图形数据库的灵活性使得能够添加新节点和节点之间的关系,从而使其能够可靠地处理实时数据。关系数据库使在数据库运行时可以添加新的表和列。

        复杂查询在图形数据库中的运行速度通常比在关系数据库中更快。关系数据库需要对数据表进行复杂的联接才能执行复杂的查询,因此该过程没有那么快。


Neo4j 图形数据库 

 Neo4j是著名的图形数据库。

 Neo4j 以原生图形数据库为核心,以自然的连接状态存储和管理数据。 图形数据库采用属性图方法。

Neo4j 最初是一个图形数据库,现已发展成为一个拥有众多工具、应用程序和库的丰富生态系统。 该生态系统允许您将图形技术与您的工作环境无缝集成。

graphQL语言

        GraphQL是由 Facebook 在 2012 年创立的一门开源查询语言

        GraphQL 是一种用于 API 的查询语言,也是用于使用现有数据完成这些查询的运行时。GraphQL 为您的 API 中的数据提供了完整且易于理解的描述,使客户能够准确询问他们需要什么,仅此而已,使 API 随着时间的推移而更容易发展,并启用强大的开发人员工具。

GraphQL 查询不仅可以访问一个资源的属性,还可以顺利地跟踪它们之间的引用。虽然典型的 REST API 需要从多个 URL 加载,但 GraphQL API 可以在单个请求中获取应用所需的所有数据。即使在较慢的移动网络连接上,使用 GraphQL 的应用程序也可以快速运行。

Neo4j GraphQL 库是一个高度灵活、低代码的开源 JavaScript 库,通过利用连接数据的力量,为跨平台和移动应用程序实现快速 API 开发。

使用 Neo4j 作为图形数据库,GraphQL 库使应用程序可以轻松地将数据视为从前端一直到存储的原生图形。 这避免了重复的架构工作,并确保了前端和后端开发人员之间的完美集成。

graph QL与OPCUA 比较优势

        与原生 Web 技术相比,OPC UA 有一些缺点:在访问数据之前需要多次往返才能建立连接,它更复杂,使应用程序开发费力;并且需要特定的客户。缺乏客户端库尤其阻碍了应用程序开发。[4]中介绍了一个工业应用示例,其中GraphQL接口允许更轻松地访问桥式起重机OPC UA服务器。为了克服OPC UA的缺点和局限性,一些论文提出了将OPC UA设置为RESTful(表征状态转移)。最近,这些作者在之前的工作中也提出了用于OPC UA服务器的GraphQL接口。GraphQL 是一种构建 Web API(应用程序编程接口)的新方法,旨在解决 REST API 的问题;这些问题,包括过度提取和获取所需数据所需的多个请求。

              OPC UA(开放平台通信统一架构)需要多次往返才能从服务器读取数据。

图形数据库(neo4j)在工业中的应用 

         在工业自动化领域主张采用基于模型的设计。 OPCUA 就是基于信息模型的通信协议。目前大多数PLC 都具备了OPC UA 服务器,OPCUA 客户端软件能够访问OPC UA 服务器中的数据。OPCUA 信息模型同样是基于节点-关系的图模型。因此,OPCUA 信息模型与图模型具有天然的相似性。

工业网关

    可以设计一个网关,将一个或多个 OPC UA 服务器的数据更新到图形数据库中。

      在网关启动时,将 OPC UA 节点结构写入图数据库,从而将 OPC UA 服务器的基本模型镜像到图数据库中。    将 OPC UA 系统的哪些根节点(以及所有子节点)镜像到图形数据库。

        在图数据库中拥有(简化的)OPC UA信息模型后,您可以在此基础上添加自己的知识图谱数据,并创建与机器的OPC UA节点的关系,以丰富OPC UA模型的数据。

工业网关的基本架构 

实现细节

通过OPCUA Client 读取所有OPC UA服务器的信息模型,将它们转换成为neo4j图模型。 

如果在OPCUA 模型中带有Tag 那么就可以将历史数据存储在InfluxDB 时间序列数据库中。         

GraphQL 的优点是只需要一个查询就可以访问多个资源的数据。

基于neoj4的模型数据库

        在工业控制系统中,需要构建各种模型数据库,它们包括OPCUA 信息模型,工业4.0 管理壳(AAS),MTP 等等,将大量的模型放置在数据库中,作为一种服务供工程设计时引用。与此同时还需要构建各种所谓的本体数据,知识库,字典。这些模型都可以在图形数据库中存储。

为OPCUA 服务器增加graphQL 访问能力

        建议将 GraphQL API 作为 OPC UA 服务器的附加接口提供。这个额外的接口将允许使用 GraphiQL 工具从浏览器访问 OPC UA 服务器的数据和自检。GraphQL 接口还将使开发人员更容易访问 OPC UA 服务器,并提高 OPC UA 与标准 Web 技术的互操作性。这将使先进的数据驱动应用程序的开发成为可能,并为工业4.0铺平道路,在工业4.0中,网络物理系统通过网络相互通信。

相关的GitHub项目:

https://github.com/AaltoIIC/OPC-UA-GraphQL-Wrapper

结束语

        有时候我在想,在工业数字化的道路上,我们一定要跟着欧洲人的各种标准兜圈子么?相比之下,我国是一个新兴的独立经济体,技术的包袱不多,IT 技术发展迅速。能否采取更加扁平化的开放自动化技术与标准体系呢?比如,选择OPCUA 作为开放自动系统的技术底座,将所有其它的技术标准和模型全部导入到OPCUA 信息模型中来,真正实现统一的模型。而不是先构建各种模型,标准,最终又转换到OPCUA 模型,一步到位难道不香么?

        标准,协议,模型的扁平化是一个有趣的话题。大多数创新源自于混搭!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/252024.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

kubectl命令

kubenetes部署服务的流程 以部署一个nginx服务来说明kubernetes系统各个组件调用关系: 1. 首先要明确,一旦kubernetes环境启动之后,master和node都会将自身的信息存储到etcd数据库中 2. 一个nginx服务的安装请求会首先被发送到master节点的ap…

世界各国都在追求“主权人工智能能力”,国家级人工智能硬件需求将剧增

NVIDIA的CEO黄仁勋最近在接受媒体采访时指出,世界各国都打算在本国内建立和运行自主的人工智能基础设施,这将全面带动NVIDIA硬件产品需求的飙升。黄仁勋表示,包括印度、日本、法国和加拿大在内的国家政府都在讨论投资“国家主权人工智能能力”…

利用jmeter完成简单的压力测试

Jmeter是一个非常好用的压力测试工具。Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好。 1、什么是压力测试 顾名思义:压力测试,就是 被测试的系统,在一定的访问压…

从小白到入门webrtc音视频通话

0. 写在前面 先会骑车,再研究为什么这么骑,才是我认为学习技术的思路,底部付了demo例子,根据例子上面的介绍即可运行。 1. 音视频通话要用到的技术简介 websocket 介绍:1. 服务器可以向浏览器推送信息;2…

Java SWT Composite 绘画

Java SWT Composite 绘画 1 Java SWT2 Java 图形框架 AWT、Swing、SWT、JavaFX2.1 Java AWT (Abstract Window Toolkit)2.2 Java Swing2.3 Java SWT (Standard Widget Toolkit)2.4 Java JavaFX 3 比较和总结 1 Java SWT Java SWT(Standard Widget Toolkit&#xff…

Yarn常见问题处理

任务出现container OOM异常导致作业失败 原因 Container内存不足或者作业数据倾斜 解决方案 检查Container相关参数,判断是否设置过小(低于4GB)。如果Container小于4GB,优先考虑调大当前作业container大小,如果是Tez任务,还需要同步调整以下参数 # tez container size…

STM32--SPI通信协议(1)SPI基础知识总结

前言 I2C (Inter-Integrated Circuit)和SPI (Serial Peripheral Interface)是两种常见的串行通信协议,用于连接集成电路芯片之间的通信,选择I2C或SPI取决于具体的应用需求。如果需要较高的传输速度和简单的接口,可以选择SPI。如果需要连接多…

探索设计模式的魅力:从单一继承到组合模式-软件设计的演变与未来

设计模式专栏:http://t.csdnimg.cn/nolNS 在面对层次结构和树状数据结构的软件设计任务时,我们如何优雅地处理单个对象与组合对象的一致性问题?组合模式(Composite Pattern)为此提供了一种简洁高效的解决方案。通过本…

记录下ibus-libpinyin输入法的重新安装

目前的版本为: 首先把现在的ibus-libpinyin卸了 sudo apt-get --purge remove ibus-libpinyin sudo apt-get autoremove 安装教程请参考 Installation libpinyin/ibus-libpinyin Wiki GitHub yilai sudo apt install pkg-config sudo apt-get install libglib2.0-de…

CSS要点总结

一、CSS 快速入门 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>css 快速入门</title><!-- 解读1. 在 head 标签内&#xff0c;出现了 <style type"text/css"></style…

初探unity中的ECS

ECS是一种软件架构模式&#xff0c;就像MVC一样。ECS最早在游戏《守望先锋》中提及到的相关链接。ECS具体是指实体&#xff08;entity&#xff09;、 组件&#xff08;component&#xff09;和系统&#xff08;system&#xff09;&#xff1a; 实体&#xff1a;实体是一个ID&a…

从源代码看Chrome 版本号

一直以来都是用Chrome 浏览器&#xff0c;但是看到Chrome 点分4 组数据的表达方式&#xff0c;总是感觉怪怪的&#xff0c;遂深入源代码了解她的版本号具体表示的内容 chrome 浏览器中显示的版本号 源代码中的版本号标识 版本号文件位于 chrome/VERSION &#xff0c; 看到源代…

SpringBoot实战(二十六)集成SFTP

目录 一、SFTP简介二、SpringBoot 集成2.1 Maven 依赖2.2 application.yml 配置2.3 DemoController.java 接口2.4 SftpService.java2.5 DemoServiceImpl.java 实现类2.6 SftpUtils.java 工具类2.7 执行结果1&#xff09;上传文件2&#xff09;下载文件3&#xff09;重命名文件&…

全链游戏的未来趋势与Bridge Champ的创新之路

为了充分探索全链游戏的特点和趋势&#xff0c;以及Bridge Champ如何作为一个创新案例融入这一发展脉络&#xff0c;我们需要深入了解这两者之间的互动和相互影响。全链游戏&#xff0c;或完全基于区块链的游戏&#xff0c;代表了游戏行业的一个重要转型&#xff0c;它们利用区…

nginx反向代理----->微服务网关----->具体微服务

今天&#xff0c;做项目的时候做项目的时候配路由出现bug&#xff0c;特此理顺一下从nginx到微服务网关再到微服务这一过程。 nginx配置 upstream admin-gateway{server localhost:21217; }server {listen 8803;location / {root F:/develop/admin-web/;index index.html;}…

LeetCode--代码详解 2.两数相加

2.两数相加 题目 难度&#xff1a;中等 给你两个 非空 的链表&#xff0c;表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的&#xff0c;并且每个节点只能存储 一位 数字。 请你将两个数相加&#xff0c;并以相同形式返回一个表示和的链表。 你可以假设除了数…

【django】建立python虚拟环境-20240205

1.确保已经安装pip3 install venv 2.新建虚拟环境 python -m venv myenv 3.安装虚拟环境的依赖包 pip install … 4.激活虚拟环境 cd myenv cd Scripts activate 激活activate.bat并进入虚拟环境 进入虚拟环境后&#xff0c;命令行前面显示&#xff08;myenv&#xff0…

AspNet web api 和mvc 过滤器差异

最近在维护老项目。定义个拦截器记录接口日志。但是发现不生效 最后发现因为继承的 ApiController不是Controller 只能用 System.Web.Http下的拦截器生效。所以现在总结归纳一下 Web Api: System.Web.Http.Filters.ActionFilterAttribute 继承该类 Mvc: System.Web.Mvc.Ac…

【Linux系统 01】Vim工具

目录 一、Vim概述 1. 文件打开方式 2. 模式切换 二、命令模式 1. 移动与跳转 2. 复制与粘贴 3. 剪切与撤销 三、编辑模式 1. 插入 2. 替换 四、末行模式 1. 保存与退出 2. 查找与替换 3. 分屏显示 4. 命令执行 一、Vim概述 1. 文件打开方式 vim 文件路径&#…

Android学习之路(29) Gradle初探

前言: 大家回想一下自己第一次接触Gradle是什么时候&#xff1f; 相信大家也都是和我一样&#xff0c;在我们打开第一个AS项目的时候&#xff0c; 发现有很多带gradle字样的文件&#xff1a;setting.gradle, build.gradle,gradle.warpper,以及在gradle文件中各种配置&#xff…