V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
fxjson
V2EX  ›  程序员

关于 go 日志中记录 request id 的疑问

  •  
  •   fxjson · 2022-09-17 11:27:07 +08:00 via Android · 1808 次点击
    这是一个创建于 840 天前的主题,其中的信息可能已经有所发展或是发生改变。

    一直有个疑问,go 业务日志中怎么在一个请求的每一条日志中记录当次请求的一个唯一请求 id ,方便根据这个唯一标识过滤所有的当次请求的日志,从而更快排查问题。知道一种比较麻烦的方式,在请求的 context 中灌入这个唯一 id,然后在各个方法中都需要参数 context ,这样在各个方法想记录日志,再从 cotext 中拿 id,这方式不优雅啊,有啥好方法吗?

    looking0truth
        1
    looking0truth  
       2022-09-17 11:42:15 +08:00
    貌似必须透传
    0987363
        2
    0987363  
       2022-09-17 11:45:38 +08:00
    http 框架的 middleware 里初始化日志的时候加上 id
    fxjson
        3
    fxjson  
    OP
       2022-09-17 12:06:37 +08:00 via Android
    @0987363 你的意思应该也是每个方法透传 context ,从 context 里面接收唯一标识
    to2false
        4
    to2false  
       2022-09-17 12:09:27 +08:00
    你的 log 组件封装个方法 `withCtx(ctx context.Context)`然后内部自己获取就好了
    to2false
        5
    to2false  
       2022-09-17 12:10:58 +08:00
    toomoy
        6
    toomoy  
       2022-09-17 13:11:03 +08:00
    nginx 生成个请求标识
    SimbaPeng
        7
    SimbaPeng  
       2022-09-17 13:18:58 +08:00
    把带上各种基础字段的 logger 对象传入 context ,下层方法用的都是上层传下来带上了各种基础字段的 logger
    fxjson
        8
    fxjson  
    OP
       2022-09-17 13:33:33 +08:00 via Android
    @to2false 那还是要各个方法传递 ctx 才能 withCtx,从而所有日志才能有这个唯一标识
    ArianX
        9
    ArianX  
       2022-09-17 14:15:20 +08:00 via Android
    middleware 在 ctx 中设置一个 id ,处理请求的整个链路都需要带上这个 ctx 。用公共的日志库提供打日志的方法,日志库封装从 ctx 把 id 取出来的逻辑
    joesonw
        10
    joesonw  
       2022-09-17 15:06:42 +08:00 via iPhone
    从 ctx 上拿 logger ,这样除了 reqeust id 以外,后面要注入其他变量,其他地方不用动。
    king888
        11
    king888  
       2022-09-17 15:25:04 +08:00
    在代码打日志哪里要用到 requestId 就在那处调用,不是很正常的一件事情,为什么这种方法不优雅
    sardina
        12
    sardina  
       2022-09-17 18:28:58 +08:00
    把当前的 goroutinue id 和 request id 关联起来,然后打日志的时候通过取当前的 goroutinue id 来打印 request id 。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   970 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 22:39 · PVG 06:39 · LAX 14:39 · JFK 17:39
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.