[发明专利]系统部署与依赖关系自动绘制系统及方法有效
申请号: | 201710903955.1 | 申请日: | 2017-09-29 |
公开(公告)号: | CN108628918B | 公开(公告)日: | 2022-03-25 |
发明(设计)人: | 梅存兵 | 申请(专利权)人: | 南京途牛科技有限公司 |
主分类号: | G06F16/958 | 分类号: | G06F16/958;H04L41/50 |
代理公司: | 南京众联专利代理有限公司 32206 | 代理人: | 叶涓涓 |
地址: | 210000 江苏省南京*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 系统 部署 依赖 关系 自动 绘制 方法 | ||
1.系统部署与依赖关系自动绘制方法,其特征在于,包括如下步骤:
step1,采集实例间服务调用日志,日志包含以下信息:调用时间、调用方IP和端口号、被调用方IP和端口号、调用的服务标识;
step2,整理日志中的所有实例间调用关系及其调用的服务,整理出每个实例上提供的所有服务,并对实例和服务进行分组,令分组完成后各组内的实例和服务均无交集,每个组对应一套系统,针对每个实例查找其对应的分组后系统或边缘系统,根据日志中实例间调用关系及服务、结合实例与系统的映射关系得到所有系统间的调用关系;
所述step2具体包括如下步骤:
step2-1,根据日志信息,得到所有的调用方实例调用被调用方实例以及被调用服务的关系data;
step2-2,分析step2-1提供服务的实例与服务的关系,整理出每个实例上提供的所有服务,记作map;
step2-3,嵌套循环遍历map,对实例和服务进行分组,令分组后任意两个组之间的实例和服务均没有交集,分组后的数据记作deploy,每一个组对应逻辑上独立部署的一套系统,每个分组记录了每个系统提供的服务列表、部署的实例列表;
step2-4,整理deploy中每一个系统的系统码;
step2-5,给予系统唯一标识;
step2-6,根据data获取所有的实例标识,整理全部的实例列表instanceList;
step2-7,遍历instanceList中的每一个实例,查找其在deploy中对应的系统,从而得到实例与系统的关系记入instanceBelong中;如果实例在deploy中不存在对应系统,则结合边缘系统ip与系统码的对应关系,得到实例与边缘系统的映射关系记入cNode中;
step2-8,将data中的客户端实例、服务端实例,结合instanceBelong、deploy、cNode进行查找,得到所有系统间的调用关系;
step3,绘制系统部署及调用关系图,图上先排列系统分组的矩形框,再绘制系统的小图标,关系图上能够显示系统的部署详情和上下游关系。
2.根据权利要求1所述的系统部署与依赖关系自动绘制方法,其特征在于,所述step2-3包括如下子步骤:
1)从一个未分组的实例a开始,将实例a放到一个新分组中去;
2)如果实例a所在的分组提供的服务列表与未分组实例b提供的服务列表交集不为空,就将实例b划分到实例a所在组中去;重复该过程直到实例a所在的组与未分组的实例服务列表交集均为空为止;
3)从1)开始重复执行,直到所有的实例都完成了分组。
3.根据权利要求1所述的系统部署与依赖关系自动绘制方法,其特征在于,所述step2-8包括如下子步骤:
初始化空变量link_temp,遍历data:
1)取得客户端实例,客户端ip,服务端实例,客户端实例调用服务端实例的服务service;
2)从instanceBelong查找客户端实例的归属系统,如果没有就从cNode中查找包含了客户端实例的系统,如果还没有就查找cNode中包含了客户端ip的系统,如前述查找中能够查到对应系统将其记为c;都找不到就进入下一次循环;
3)从deploy中查找包含了服务service的系统,如果没有就从instanceBelong找出服务端实例对应的系统,如前述查找中能够查到对应系统将其记为s,如果都找不到就进入下一次循环;
4)在link_temp中记录系统c调用了系统s的服务service;
5)link_temp数据去重,整理数据格式,得到系统间调用的服务列表。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南京途牛科技有限公司,未经南京途牛科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710903955.1/1.html,转载请声明来源钻瓜专利网。
- 上一篇:文档管理系统和管理设备
- 下一篇:情景地消除查询的歧义