我是靠谱客的博主 烂漫时光,这篇文章主要介绍golang日志服务器_Golang使用映射的诊断上下文进行日志记录,现在分享给大家,希望可以做个参考。

How can I achieve MDC Logging (Java) in GoLang?

I need to add UUIDs in all server logs in order to be able to trace concurrent requests.

解决方案

Java MDC relies on thread local storage, something Go does not have.

The closest thing is to thread a Context through your stack.

This is what more and more libraries are doing in Go.

A somewhat typical way is to do this via a middleware package that adds a request id to the context of a web request, like:

req = req.WithContext(context.WithValue(req.Context(),"requestId",ID))

Then, assuming you pass the context around, you pull it out with ctx.Value("requestId") and use it wherever it makes sense.

Possibly making your own custom logger function like:

func logStuff(ctx context.Context, msg string) {

log.Println(ctx.Value("requestId"),msg) // call stdlib logger

}

There's a bunch of ways you may want to handle this, but that's a fairly simple form.

最后

以上就是烂漫时光最近收集整理的关于golang日志服务器_Golang使用映射的诊断上下文进行日志记录的全部内容,更多相关golang日志服务器_Golang使用映射内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(95)

评论列表共有 0 条评论

立即
投稿
返回
顶部