1.一种云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述方法包括以下步骤:第一步:构建服务数据可视化建模与匹配方法的架构,包括三个模块:数据建模、图形建模和匹配引擎;
1.1、数据建模:从Internet获取的REST服务经解析器解析后进行注册,存储于缓存cache或数据库Database中,自动调用后所获取的基于JSON的REST服务数据,通过服务数据建模将服务数据转变为标准化模型,并抽取出主要数据结构生成元数据树MDT;
1.2、图形建模:对多种配置型可视化工具所支持的图形进行数据结构分析与归纳,整理出主要图形的通用数据结构及数据映射关系,再根据上述信息进行可视化图形建模,创建描述性可视模型VT;
1.3、匹配引擎:调取数据建模所生成的MDT,从MDT中搜索与VT中的图形结构模型匹配的数据结构片段,来查询源数据可生成的图形种类,并根据映射关系信息自动化生成可视化图形;
第二步:定义元数据树MDT,包括根节点TRoot、索引节点INode、数据节点DNode,同时用深度level来表示节点在树结构中的层数,根节点默认为第一层,即level=1,步骤如下:
2.1、根节点:MDT的根节点,即MDT的起始节点;
2.2、索引节点:代表JSON数据中每一个关键字KEY,但不包括JSON数据中最内层的“键-值”对的关键字,索引节点为非根节点、非叶子节点;
2.3、数据节点:代表JSON数据中最内层的“键-值”对,存储为叶子节点;
第三步:读取调用的REST API所返回的JSON数据,将JSON数据集ds作为建模算法的输入,对ds进行树形结构建模,步骤如下:
3.1、创建一棵根节点为TRoot的MDT,TRoot是起始节点,根节点的深度level默认为1;
3.2、读取JSON数据集ds,如果是首次读取ds,设置ds的第一个元素为当前元素,元素包括关键字KEY及其值VALUE;否则设置ds的下一个元素为当前元素;若JSON数据最外层就是ARRAY,则TRoot的isMark=1,元素数量arrayNum为ARRAY元素个数;
第四步:通过剪枝的方法,保留基本的数据结构信息,剪除相同的重复数据结构,缩小模型的体量,但仍然保留基础的数据结构,降低JSON数据结构所带来的查询开销;
第五步:对可视化图形进行分类,归纳总结各类图形的属性及结构特征,通过建模创建一种可视模型树VT,来形式化地表述各类图形信息;
第六步:将可视模型树VT与MDT进行匹配查询,查找MDT中与VT的各个StructModel匹配的片段,并根据Mapping信息进行数据映射,生成可视化图形。
2.如权利要求1所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述第四步的处理过程包括以下步骤;
4.1、从level=1的TRoot开始,按广度优先策略,按层遍历MDT的根节点与索引节点;广度优先策略将按level逐层遍历MDT,从level=1的第一层开始遍历,当level层的节点遍历完成后,再继续遍历level+1层的节点;
4.2、将MDT的TRoot存入遍历队列;
4.3、按遍历队列顺序,读取每个节点的isMark属性;
4.4、当遍历队列中全部为数据节点时或遍历队列为空时,停止遍历,结束方法;
4.5、输出剪枝后的MDT。
3.如权利要求2所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述步骤4.3的处理过程为:
4.3.1、若遍历到的节点的isMark属性值为1,则保留当前节点的第一个子节点,剪除其余的子节点及其子节点的子树结构,跳转至步骤4.3.4;
4.3.2、若遍历到的节点的isMark属性值为0,则不进行任何操作,跳转至步骤4.3.4;
4.3.3、若遍历到的节点为数据节点,将当前节点从遍历队列中删除,跳转至步骤4.3;
4.3.4、将当前遍历到的节点的子节点加入遍历队列,并将当前节点从遍历队列中删除,再跳转至步骤4.3。
4.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述第五步包括以下步骤:
5.1、定义VT包括基础属性BASICATTRIBUTE和可视结构DVSCHEMA两个部分,形式化定义如(11),其中BASICATTRIBUTE保存了图形标题、副标题及其他文本样式的通用信息;
(11)、VisualModel::=
5.2、BASICATTRIBUTE包括三个属性:标题title、子标题subtitle、属性attributes,形式化定义如(12),title用于保存最终生成的可视化图形的标题,subtitle用于保存最终生成的可视化图形的子标题,attributes用于保存最终生成的可视化图形的位置、颜色组合、字体、字号设置参数;
(12)、BASICATTRIBUTE::=
5.3、BASICATTRIBUTE根据图形所需的数据类型、图形数据结构、图形维度将常见的可视化图形归纳为四种基础类别:一般图形General、拓扑图Topology、地图Map、文本图形Text,形式化定义如(13);
(13)、DVSCHEMA::=
5.4、步骤5.3中的四种基础类别下属均分别包含两个属性:图形类型和图形结构,VType保存了该类别所属图形种类,StructModel保存了该类别所属图形的基本可视化结构,形式化定义如(14),“A::B”表示“A包含了属性B”;
(14)、DVSCHEMA::=
5.5、步骤5.4中四种基础类别均有各自的映射关系,描述了各类图形的数据结构、数据维度、图形结构关系、数据映射位置信息;根据Mapping信息并结合图形的数据结构,可以抽象出各类图形的基本可视化结构StructModel,步骤三中所生成的MDT将与StructModel进行匹配,来判断REST API的返回数据能够生成何种可视化图形。
5.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述第六步的处理过程包括以下步骤:
6.1、解析VT中四种基础类别的StructModel,提取每种StructModel中的临时根节点及其子结构,每一个临时根节点及其子结构构成的树结构片段将作为查询子图,根据步骤
5.5.1至5.5.4可以提取出六个查询子图:General类型的StructModel的下属Root为起点的子结构,Topology类型的StructModel的下属分别以Root1和Root2为起点的两个子结构,Map类型的StructModel的下属分别以Root1和Root2为起点的两个子结构,Text类型的StructModel的下属Root为起点的子结构;
6.2、将MDT作为目标图,所述6.1中的六个查询子图依次作为输入,每输入一个查询子图就遍历一次MDT,查找与当前输入的查询子图匹配的MDT片段;
6.3、按照广度优先策略,按层遍历MDT;
6.4、将MDT的节点从TRoot开始,按层数从小到大的顺序存入遍历队列Q;
6.5、按遍历队列Q的顺序,将当前遍历到的节点Ni放入集合S1,并将查询子图的临时根节点M放入集合S2;
6.6、比较S1与S2中节点的结构是否一致,即S1与S2中每一个对应节点的父子关系是否一致;若S1与S2中节点的结构一致,将M的子节点的集合L2中的节点依次加入集合S2;跳转至步骤6.8;
6.7、若S1与S2中节点的结构不一致,设置i=i+1,清空S1与S2,跳转至步骤6.5;
6.8、每当S2中新增一个节点L2k时,进行步骤6.9;
6.9、读取节点Ni的子节点的集合L1中的节点,依次加入集合S1,S1中每加入一个节点L1j就与S2进行一次结构匹配;
6.10、若L1与L2中的节点都已遍历完,清空L1和L2,然后在MDT中查找出S1中的叶子节点对应的原节点,并将这些原节点的子节点重新生成L1;在查询子图中查找出S2中叶子节点对应的原节点,并将这些原节点的子节点重新生成L2,跳转至步骤6.6;
6.11、若查询子图的节点均已加入S2,则将S1中的结构保存于集合R中,并清空S1、S2、L1、L2,设置i=i+1,跳转至步骤6.5;
6.12、当遍历队列Q中的节点遍历完成后,输入下一个查询子图,重复步骤6.5至6.12;
6.13、直至六个查询子图都完成了查询,根据输出的匹配结果集合R,按照Mapping结构将MDT中的数据映射对应类型的图形结构中,从而生成可视化图形。
6.如权利要求5所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述步骤6.9的处理过程为:
6.9.1、若S1与S2匹配成功,设置k=k+1,向S2加入节点L2K,跳转至步骤6.8;
6.9.2、若S1与S2匹配失败,则移除S1中刚加入的节点L1j,设置j=j+1,向S1中加入节点L1j,跳转至步骤6.9。
7.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述2.1中,所述根节点内包含以下信息:
2.1.1、星标isMark:记录JSON数据中最外层结构是否为数组类型,若是用1标记,若否用0标记;isMark形式化定义表述如(1)(2),isMark的数据类型为数字NUMBER,若JSON数据中“键-值”对中的值VALUE为数组ARRAY,则isMark=1,否则isMark=0;“#”为数据类型定义符,“::=”为赋值符,〖A→condition⊕:
(1)、“isMark”#
(2)、“isMark”::=〖“VALUE”→ARRAY⊕<1>:<0>〗
2.1.2、元素数量arrayNum:若当前节点的isMark为1,则记录数组元素个数,若当前节点的isMark为0,则用0标记;arrayNum形式化定义表述如(3)(4),arrayNum属性值为数字NUMBER类型,若JSON数据中“键-值”对中的值VALUE为ARRAY,则arrayNum等于VALUE数组的长度,否则arrayNum=0;
(3)、“arrayNum”#
(4)、“arrayNum”::=〖“VALUE”→ARRAY⊕
8.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述2.2中,所述索引节点内包含以下信息:
2.2.1、节点名称name:name的数据类型为字符串STRING,name属性值为JSON数据中“键-值”对中的关键字KEY;name形式化定义表述如(5)(6);
(5)、“name”#
(6)、“name”::=
2.2.2、节点值类型vType:vType是JSON数据中“键-值”对中的值VALUE的数据类型,属性值为对象OBJECT、数组ARRAY、字符串STRING、数字NUMBER、TRUE、FALSE之一;vType形式化定义表述如(7);
(7)、“vType”::=[OBJECT|ARRAY|STRING|NUMBER|TRUE|FALSE]
2.2.3、星标(isMark):记录JSON数据中,以当前节点名称name作为关键字的“键-值”对中的值VALUE是否为数组类型,若是用1标记,若否用0标记;isMark形式化定义表述同步骤
2.1.1中的(1)(2);
2.2.4、元素数量arrayNum:若当前节点的isMark为1,则记录“键-值”对中的值VALUE的数组元素个数,若当前节点的isMark为0,则用0标记;arrayNum形式化定义表述同步骤
2.1.2中的(3)(4)。
9.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述2.3中,所述数据节点内包含以下信息:
2.3.1、节点名称name:保存JSON数据中“键-值”对中的关键字KEY,数据类型为字符串STRING;name形式化定义表述同步骤2.2.1中的(5)(6);
2.3.2、节点值nValue:nValue的数据类型为STRING,属性值为JSON数据中“键-值”对中的值VALUE;nValue形式化定义表述如(8)(9);
(8)、“nValue”#
(9)、“nValue”::=
2.3.3、节点类型type:保存JSON数据中“键-值”对中的值VALUE的数据类型,为“str”、“num”或NULL,其中“str”代表type的数据类型为STRING,“num”代表type的数据类型为NUMBER,NULL表示type的属性值为空;type形式化定义表述如(10);
(10)、“type”::=[“str”|“num”|NULL]。
10.如权利要求1~3之一所述的云计算环境下面向REST架构风格的服务数据可视化建模与匹配方法,其特征在于,所述步骤3.2的处理过程如下:
3.2.1、若VALUE的数据类型非OBJECT,同时非ARRAY,创建深度为level+1的数据节点,节点名称name为关键字KEY,节点值nValue为值VALUE,节点类型type为值VALUE的数据类型;完成后跳转至步骤3.2;
3.2.2、若VALUE的数据类型为ARRAY,创建深度level’=level+1的索引节点,节点名称name为关键字KEY,节点值类型vType为ARRAY,isMark=1,元素数量arrayNum为当前VALUE数组中的元素个数;
3.2.3、若VALUE的数据类型为OBJECT,创建深度level’=level+1的索引节点,节点名称name为每个OBJECT元素中的关键字KEY,节点值类型vType为每个OBJECT元素中的值VALUE的数据类型;若当前vType为ARRAY,则isMark=1,元素数量arrayNum为当前VALUE数组中的元素个数;若当前vType不为ARRAY,则isMark=0,arrayNum=0;
3.2.4、将步骤3.2.3中VALUE数组作为新的JSON数据集ds’,跳转至步骤3.2。