当前位置: 首页 > news >正文

地方政府网站建设中存在的问题360推广官网

地方政府网站建设中存在的问题,360推广官网,制作网站,网站设计需求方案背景 最近线上的日志全局追踪 traceId 不好使了,不同请求经常出现重复的 traceId,或者通过某个请求的 traceId 追踪搜索,检索出了与该请求完全不相干的日志。我领导叫我去排查解决这个问题,这里我把我排查的过程思路以及如何解决…

背景

最近线上的日志全局追踪 traceId 不好使了,不同请求经常出现重复的 traceId,或者通过某个请求的 traceId 追踪搜索,检索出了与该请求完全不相干的日志。我领导叫我去排查解决这个问题,这里我把我排查的过程思路以及如何解决这个问题稍微记录下。

全链路追踪原理:Spring web 的拦截器(HandlerInterceptor)+ 阿里的一个开源工具 (TransmittableThreadLocal 支持主线程到线程池的透传)+ feign 的 RequestInterceptor

排查过程

在排查日志之前,我经验告诉我,这大概率是 TTL 的 agent 代理与线上的 arm 监控代理冲突,导致线程池透传 traceId 没生效导致的(我以前也碰到过这类问题)

  1. 查看每个前端请求接口的日志打印,发现不同的请求确实存在重复的 traceId。

image-20230330161945222

接着,我去看了下打印这行日志的实现,如下图,是通过一个 AOP 切面拦截所有的rest 请求去打印。其中,打印日志使用了线程池。

image-20230330162624180

结论一:证实了我的猜测,线程池透传 traceId 没生效。也就是说,所有接口业务中使用到线程池的都可能会串 traceId。

  1. 当时我以为这就完了。在一次偶然的排查线上问题中发现,基本在同一时间,没有使用到线程池的两个业务接口,打印的日志的 traceId 是一样的。

    我首先想到是,是不是接口请求接口没清除 traceId 呢,也就是没有重写 拦截器的 org.springframework.web.servlet.handler.HandlerInterceptorAdapter#afterCompletion 方法呢?

    image-20230330165201532

    我去看一了下源代码,虽然没有重写afterCompletion() 方法在每次请求结束之后清除 traceId,但看 如上的preHandle()方法的代码逻辑,不清除也不要紧,如上代码所示,当在请求头中获取 traceId 不存在时会重新生成一个 traceId。

    初步猜测:

    1)IdWorker 生成的随机id重复了?

    不太可能吧,IdWorker 用的是雪花算法啊,尽管在同一毫秒,并发量不高的话也不会生成重复的…

    2) IdWorker 非单例的原因?

结论二:短时间内,存在 IdWorker 生成了重复的 traceId。

解决方案

  1. 关于第一个线程池透传 traceId 没生效问题。主要有两个原因:

    1.1 项目压根就没有对线程池做 TTL 的包装增强(也就是项目启动参数没有加上 TTL 的 agent 方式代理),需要把参数给加上。

    -javaagent:D:\AAA_pengyu\respository\com\alibaba\transmittable-thread-local\2.11.5\transmittable-thread-local-2.11.5.jar
    

    1.2 实际上,尽管在所有项目把 TTL 的 agent 方式代理启动参数家加上也还是会失效的。前面说了,TTL 的 agent 代理与线上的 arm 监控代理冲突。

    针对和阿里云的沟通,修改方案如下:

    image-20230330173838128

  2. 关于 IdWorker 生成了重复的 traceId。

    在测试调整过程中,我把IdWorker 改成单例模式之后,也还是会存在 id重复问题。

    原因是构造 IdWorker 时 workerId,datacenterId,sequence 都为同一个字符串的原因,IdWorker 生成的 随机id 是依赖这三个参数。

    所以不同服务根据当前机器ip、mac 等参数动态生成就好了

最后,经过如上的修改之后,公司的全链路日志追踪就好了。

http://www.ds6.com.cn/news/24477.html

相关文章:

  • 网站的盈利方式谷歌seo怎么优化
  • 网站建设轮播图游戏代理平台哪个好
  • 厦门建设工程招标中心的网站网站建设设计
  • 北京免费网站制作百度收录量查询
  • 网站建设的发票怎么做会计分录淘宝关键词搜索排行榜
  • 邵阳今日头条新闻sem和seo的关系
  • 建网站算法购物网站推广方案
  • logo设计竞标网站廊坊快速优化排名
  • 一起做网店网站打不开百度广告一天多少钱
  • 专业网站建设软件开发百度信息流广告怎么投放
  • 大连响应式网站制作seo优化的优点
  • 源代码 培训 网站seo优化网站百度技术
  • 台州网站建设技术支持长沙网络营销推广公司
  • 政务网站建设情况汇报百度指数介绍
  • 电子商务网站开发方式sem代运营公司
  • 山东省建设厅的网站营销推广网
  • 聊天网站制作教程重庆seo推广
  • xblog wordpress广州网站优化运营
  • 如何编写一个app关键词优化包含
  • 自己怎样建立个人网站怎样注册一个自己的平台
  • 创新网站建设工作室计算机基础培训机构
  • 万博法务网站网络推广公司加盟
  • 做安全宣传的是什么网站如何做好百度推广
  • 怎么查域名注册商seo营销方案
  • 眼镜东莞网站建设好项目推荐平台
  • 网站缩略图制作杭州疫情最新消息
  • 律师论坛网站模板seo分析师招聘
  • 深圳防疫最新政策福州seo建站
  • 柳市网站建设哪家好企业营销策划
  • 网站建设视频lseo全称