iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Predix Asset Service深度分析
  • 719
分享到

Predix Asset Service深度分析

2024-04-02 19:04:59 719人浏览 泡泡鱼
摘要

前言在IioT领域,面临着保存海量数据的挑战,具体到Asset层面,则要保存物理对象,逻辑对象,复杂的关系,并支持对象间的组合,分类,标签和高效查询。总结来说,可以归纳为如下几种需求: 灵活的建模

前言

在IioT领域,面临着保存海量数据的挑战,具体到Asset层面,则要保存物理对象,逻辑对象,复杂的关系,并支持对象间的组合,分类,标签和高效查询。总结来说,可以归纳为如下几种需求:

 

  1. 灵活的建模风格:支持不同业务领域业务对象

  2. 支持自定义属性:可以是简单的字符串,也可以是对象

  3. 支持对象间关系:层次或图关系

  4. 支持对象间组合:如电机由线圈和转子组成

  5. 支持分类:对对象做宏观分类并保存公共属性

  6. 支持标签:方便用户查询

  7. 支持灵活和高性能查询:支持针对属性,针对关系,层次等查询。

  8. 操作历史:操作日志和审计

  9. 业务能力扩展:脚本

架构

Predix架构如下所示:

Predix Asset Service深度分析

 

Client应用可以通过REST API服务获取asset数据。这些接口提供了JSON形式的接口,用户可以通过POST形式传递这些数据。为了使用这些API,应用程序发送https请求并解析响应。可以使用任何WEB开发语言解析。

  • Representation layer

Representation Layer将数据由jsON转换为内部图形式表示,也负责完成相反的过程。

  • Query engine

Query engine允许开发者使用JSON AND Graph Expression(GEL)来获取Asset Data Store中保存的任意对象或对象属性的数据。

  • Audit History Service

提供API用来获取Asset Service库中REST请求的历史信息。

  • Script engine

使用户能够将定制的业务逻辑绑定到Asset Service的REST API上。

  • Cassandra graph database

Assert Service将数据保存于Apache Cassandra NoSQL数据库

数据模型

asset

Asset模型可以理解为物理设备在虚拟世界的映射,Asset不但包含设备本身,也包含该设备如何组织和关联的信息。

classification

对asset进行分类,并保存其公共信息。

custom modeling object

自定义的模型,用来进一步进行描述,如生产商等。

API CateGoryDescription
Assets典型的,我们采用层次结构定义asset,由parent asset和一个或多个child asset组成。我们可以将asset与一个classification或任意数目的custom modeling object关联。Asset可以包含任意多个用户自定义属性(custom-defined attribute)。

一个asset也可独立存在于系统中,不与任何的其他建模元素关联。
Classifications

采用树状结构组织,并了一种对asset进行分组和跟踪公共属性的手段。一个classification可以指向多个asset。classification的任意层次上均可以指定attribute。

Custom modeling objects

定制模型对象(custom modeling object)是层次化的,我们可以使用它为asset提供更多的信息。例如,我们可以为asset location,manufactureer等创建单独的对象。一个location可以与多个asset关联,类似的,一个asset也可以关联多个location。

模型示例

Predix Asset Service深度分析

Fleets Sample JSON

{

"uri":"/fleets/up-1",

"name":"UNIOn Pacific Fleet 1",

"customer":"/customers/union-pacific"

},

Manufacturers Sample JSON

"uri":"/manufacturers/GE",

"name":"General Electric Transportation",

"year_founded":"1892",

"hqLatLng":{

        "lat":41.881138, 

        "lng":-87.640666}

}

Engines Sample Data

{

"uri":"/engines/v12-1",

"type":"7FDL",

"horsepower":"4400",

"stroke":"230",

"bore":"220",

"RPM":"2400",

"manufacturer":"/manufacturers/GE"

}

Locomotives Sample JSON

{

"uri":"/locomotives/1",

"type":"Diesel-electric",

"model":"ES44AC",

"serial_no":"001",

"emission_tier":"0+",

"fleet":"/fleets/up-1",

"manufacturer":"/manufacturers/GE",

"engine":"/engines/v12-1",

"installedOn":"01/12/2005",

"dateIso":"2005-12-01T13:15:31Z",

"hqLatLng":{

"lat":33.914605,

"lng":-117.253374

}

}

从上面的例子可以看出模型是如何组织的。

存储分析

Asset的存储要考虑两个部分,json-schema和json。json-schema是json的校验标准,任何对存储系统的修改都需要使用json-schema校验。更加抽象的思考,json-schema类似于面向对象的类,而json则是类的实现:对象。只是这种实例化是由RESTAPI触发的,且合法性由json-schema保证。

 

由于工业领域需要面对海量对象,海量关系及多种结构的数据对象(blob value,,picture, log)等,传统的sql数据库必然无法满足这些需求,且对于JSON来说,最适合应用key-value数据库类型,当然该数据库需要提供良好的性能及可扩展性。

 

经过近些年的发展,cassandra与HBase在不同领域内的应用出现了分化,hbase纪玉hadoop,支持mapReduce,更加适合于大数据计算的场景;而cassandra除了在范围查询性能落后与hbase之外,在易用性,可扩展性,健壮性(无管理节点),以及在大多数的性能应用场景上对hbase存在优势,因此考虑使用cassandra作为asset的存储。

 

具体的,使用cassandra要满足如下的要求:

 

  • 良好的横向扩展性

  • 良好的可维护性

  • 高性能

  • 支持历史记录存储

  • 能够扩展关系存储及查询

可扩展性

Predix提供了javascript语言支持更多的自定义应用。

 

JS支持是jdk自带的功能,而Predix将此功能应用在REST API上,能够在REST API的执行前后运行JS脚本,实现功能的扩展。其中REST API既可以是资源的CRUD API,也可以是自定义API。其执行逻辑为:开始--->(JS代码)--->REST API--->(JS代码)-->系统通知

 

也即JS代码可以选择在REST API执行前后执行,如果JS代码在REST API执行前,则可用于输入数据校验等,如果在REST API执行后,则可进行通知发送等应用。为了更加灵活的使用JS代码,JS代码中可以引用已经定义的工具方法(Predix提供),也可以调用其他REST API接口。

 

JS代码执行时工业云应用必备的部分,如SCADA系统和Thingwrox均提供了JS代码执行功能。但Thingwrox的JS执行依附于Thing本身(自定义方法)及订阅,而Predix则基于对已有REST API的封装(当然也支持自定义的REST API),总的来说Thingwrox实现的功能,predix也能实现。

 

例如:

        1. 调用系统方法(predix和thingwrox均提供了系统方法)

        2. 调用asset的属性(均可,thingwrox可以在脚本中通过this.引用)

        3. 调用asset的方法(thingwrox可以,predix不明)

        4. 调用其他asset的属性(predix通过restapi查询)

        5. 调用其他asset的方法(可以实现,只要是REST API形式暴露)

        6. 执行结果返回(predix可以通过消息队列返回数据)

        

关键技术

JSON-SCHEMA

Http://json-schema.org/,

 

用以描述JSON的数据结构并做验证,JSON-SCHEMA是静态JSON描述,本身不具有任何约束力,需要在实现中加以限制:如执行新增操作时必须验证SCHEMA。

 

CASSANDRA

CASSANDRA是一个key-value数据库,具有高性能,高可靠性,去中心化等特性,并支持GRAPH扩展。

 

http://www.cnblogs.com/loveis715/p/5299495.html 

GEL

如果数据只能存储而不能查询,那就没有任何意义。predix定义了GEL语言用于查询Asset数据,该查询语言是灵活的,支持分页,过滤,正则表达式及关系查询。Asset服务就是要存储所有的模型数据,因此不能针对具体需求做针对性的开发。

 

在Asset  Service中,专门存在查询引擎(Graph Expression Lanauge Query Engine)完成这一功能,这也是工业云平台开发中所必须的。

 

业界比对

这里主要与Thingwrox做比对,Thingworx更是一个物联网平台,而Predix是工业云平台,定位不同,决定了这两个平台在设计上的取舍不同。

 

从建模进行比较,Thingworx弱化了多租户概念,并且基于对类-对象的抽象,给出了Thing-ThingTemplate-ThingShape的模型,能够对每一物理/逻辑实体进行建模。如一个泵,或者是以datasource;而Predix更偏重与处理工业领域的物理实体映射,并不试图建立一个包含一切的建模环境,这种取舍,在工业领域是可以理解的。


您可能感兴趣的文档:

--结束END--

本文标题: Predix Asset Service深度分析

本文链接: https://www.lsjlt.com/news/37096.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 深度分析java dump文件
    目录JVM dump获取JVM dump文件dump文件分析结构详解文件头java一个类的成员变量有两种类型内容块块头gc root类对象基本信息说明实例对象基本类型数组基本信息说明...
    99+
    2024-04-02
  • ElasticSearch 深度分页示例解析
    目录1 前言2 from + size 分页方式2.1 Query 阶段2.2 Fetch 阶段2.3 ES 示例2.4 实现示例2.5 小结3 Scroll 分页方式3.1 执行过...
    99+
    2023-02-22
    ElasticSearch 深度分页 ElasticSearch 分页
  • oracle undo段头的深度分析
    产生一个事物 ...
    99+
    2024-04-02
  • 如何深度分析jvm中dump文件
    这篇文章将为大家详细讲解有关如何深度分析jvm中dump文件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JVM dumpjava内存dump是jvm运行时内存的一份快照,利用它可以分析是否...
    99+
    2023-06-16
  • Python深度学习算法实例分析
    本篇内容主要讲解“Python深度学习算法实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python深度学习算法实例分析”吧!最小二乘法所有的深度学习算法都始于下面这个数学公式(我已将其...
    99+
    2023-06-03
  • Python-OpenCV深度学习的示例分析
    这篇文章将为大家详细讲解有关Python-OpenCV深度学习的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 计算机视觉中的深度学习简介深度学习推动了计算机视觉领域的深刻变革,我们首先解释深...
    99+
    2023-06-22
  • MySQL深度分页
    1. 什么是深度分页 深度分页问题的本质是在 MySQL 数据库中,通过 LIMIT 和 OFFSET 关键字进行分页时,MySQL 需要在每次查询时扫描整张表,直到找到当前页的数据。这种查询方式需要...
    99+
    2023-10-02
    mysql 数据库 sql
  • Vue.js之slot深度复制的示例分析
    这篇文章给大家分享的是有关Vue.js之slot深度复制的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言在Vue中,slot是一个很有用的特性,可以用来向组件内部插入...
    99+
    2024-04-02
  • Java中深度优先与广度优先的示例分析
    这篇文章给大家分享的是有关Java中深度优先与广度优先的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发...
    99+
    2023-05-30
    java
  • kubernetes中Service的示例分析
    这篇文章主要介绍了kubernetes中Service的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一:体系结构图二:yaml举例apiVersion: v1kin...
    99+
    2023-06-04
  • Java中对HashMap的深度分析与比较(转)
    Java中对HashMap的深度分析与比较(转)[@more@]在Java的世界里,无论类还是各种数据,其结构的处理是整个程序的逻辑以及性能的关键。由于本人接触了一个有关性能与逻辑同时并存的问题,于是就开始研究这方面的问题。找遍了大大小小的...
    99+
    2023-06-03
  • 阿里云与数据库一个深度分析
    阿里云是中国最大的云计算服务提供商之一,也是全球领先的云计算服务提供商之一。本文将深入探讨阿里云与数据库的关系,并详细阐述两者如何携手合作,为客户提供更优质的服务。 阿里云与数据库:一个深度分析随着云计算的发展,数据库的重要性越来越突出。数...
    99+
    2023-11-22
    阿里 深度 数据库
  • 深度分析:golang系统的优势与劣势
    标题:深度分析:Golang系统的优势与劣势,需要具体代码示例 Golang,又称Go语言,是一种由Google开发的编程语言,自2009年发布以来,逐渐成为许多开发者喜爱的选择。本文...
    99+
    2024-02-28
    golang 优势 劣势 go语言 标准库
  • 如何深度解析JVM
    如何深度解析JVM,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先这里澄清两个概念:JVM实例和JVM执行引擎实例,JVM实例对应了一个独立运行的Java程序,而JVM执行引...
    99+
    2023-06-17
  • Angular中Component/Service的示例分析
    小编给大家分享一下Angular中Component/Service的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!关于Angular Componentcss样式的作用域、Shadow DOMShadow DOM...
    99+
    2023-06-15
  • 如何深度解析Kafka
    如何深度解析Kafka,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。背景介绍Kafka简介Kafka是一种分布式的,基于发布/订阅的消息系统。主要设计目标如下:...
    99+
    2023-06-17
  • Dotnet Core Windows Service的示例分析
    这篇文章将为大家详细讲解有关Dotnet Core Windows Service的示例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。在dotnet 中有topshelf 可以很方便的写...
    99+
    2023-06-19
  • JavaScript树结构深度优先算法实例分析
    这篇文章主要介绍了JavaScript树结构深度优先算法实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript树结构深度优先算法实例分析文章都会有所收获,下面我们一起来看看吧。什么是树在现实...
    99+
    2023-07-02
  • Java深度复制功能与用法实例分析
    本文实例讲述了Java深度复制功能与用法。分享给大家供大家参考,具体如下:写在前面:什么是深度复制?在Java里面,在创建一个对象,我们通常会有一个引用指向该对象,当我们通过引用变量改变对象的值(属性)时,引用是不变的,变的是内存里面的那块...
    99+
    2023-05-30
  • vue scoped与深度选择器deep的原理分析
    目录scoped的作用deep作用总结JS引入模块化概念后,变得更易于开发维护,但是css样式由于其特殊性,一直没有实现模块化,scoped的出现就是为了实现样式模块化,其本质利用属...
    99+
    2022-11-13
    vue deep 原理 vue scoped的原理 深度选择器deep vue scoped
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作