[发明专利]微服务架构下的分布式大数据日志链路跟踪方法及系统有效
| 申请号: | 202011566084.7 | 申请日: | 2020-12-25 |
| 公开(公告)号: | CN112612675B | 公开(公告)日: | 2023-02-28 |
| 发明(设计)人: | 刘宏亮;李铭;张丽丽;张辉;贾立平 | 申请(专利权)人: | 山东经伟晟睿数据技术有限公司 |
| 主分类号: | G06F11/30 | 分类号: | G06F11/30;G06F11/32;G06F11/34 |
| 代理公司: | 济南圣达知识产权代理有限公司 37221 | 代理人: | 张庆骞 |
| 地址: | 250101 山东省济南市高*** | 国省代码: | 山东;37 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 微服 架构 分布式 数据 日志 跟踪 方法 系统 | ||
1.一种微服务架构下的分布式大数据日志链路跟踪方法,其特征在于,包括:
当微服务模块接收到调用请求后,判断当前微服务模块是否为第一次调用,若是,则生成链路唯一标识traceID,再生成业务方法唯一标识spanID;否则,直接生成spanID,同时标记对应关联的traceID及起始时间戳信息;
根据请求中是否存在父业务方法唯一标识parentSpanID,来判断当前业务方法是否为第一次调用的业务方法,并更新调用链中的spanID关系;
执行当前业务方法时缓存微服务模块所在服务器IP地址、微服务模块名称、业务方法名称、traceID、spanID、parentSpanID及业务方法开始执行时间信息;
根据链路日志跟踪标记来执行日志跟踪记录,将日志信息与调用链路信息和微服务模块运行性能信息分别进行绑定,形成日志记录并将其按照调用链路信息进行排序处理;
业务方法执行完毕时,绑定微服务模块运行的性能数据与调用链路信息,将排序后的日志记录压缩后发送到日志存储服务器,然后删除调用链路对应的缓存数据,释放内存空间;
根据请求中是否存在父业务方法唯一标识parentSpanID,来判断当前业务方法是否为第一次调用的业务方法;
若当前业务方法为第一次调用的业务方法,则将当前业务方法对应的父业务方法parentSpanID绑定为null,否则将当前业务方法对应的父业务方法绑定为请求参数中的parentSpanID;
在执行当前微服务业务方法的过程中,如果业务方法中有记录日志的操作,则先将日志内容记录到微服务模块所在服务器的本地文件系统中,然后检查是否有进行链路日志跟踪的标记标量;
所述分布式大数据日志链路跟踪方法还包括:当前微服务是否继续调用下游微服务,若是,则将调用请求中的parentSpanID设置为当前的spanID后,发起对下游微服务的调用;否则,检查当前微服务是否执行完毕;
其中,微服务性能数据指的是微服务运行日志,微服务运行日志包括日志级别、操作人、日志时间、日志所在服务器IP和日志描述信息。
2.如权利要求1所述的微服务架构下的分布式大数据日志链路跟踪方法,其特征在于,如果没有记录日志的操作,则直接检查是否有进行链路日志跟踪的标记标量。
3.如权利要求1所述的微服务架构下的分布式大数据日志链路跟踪方法,其特征在于,如果需要进行日志跟踪记录,则从缓存中获取traceID、spanID信息,然后根据traceID和spanID为当前日志记录生成自增序列logOrder,并将logOrder以及当前日志信息追加到缓存中对应的日志有序集合列表中。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于山东经伟晟睿数据技术有限公司,未经山东经伟晟睿数据技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011566084.7/1.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置





