寻找用于记录的调用或线程ID

时间:2013-10-01 11:42:58

标签: logging go

我正在重新编写用golang编写的小型Web应用程序的日志记录。由于外部要求,日志记录已在一个地方被隔离,因此我们以后可能会切换到日志记录服务器。 (不是我的想法 - 我保证....)尽管如此,我们现在能够使用标准库的部分和我们传递的用户/会话结构来记录日期/时间,行号,用户和消息等常见内容。周围。

但是 - 这就是问题 - 在较低级别的方法中,为了记录而传递会话只是为了获取用户名是一种浪费。所以我想找一些其他的东西用来在日志文件中找到一个特定的请求。我确信有一些我没有想到的明显的东西。

到目前为止的想法:

  • Java日志记录框架可以打印出线程ID,在这种情况下也是如此。只是它在golang中被称为其他东西?
  • 以某种方式使用户/会话结构事物可以全局访问。 (仍然需要传递会话ID,除非有一个线程用作查找键。回到想法1。)
  • 无论如何,
  • 放弃并传递用户/会话结构。
  • 不在最低级别记录错误,但仅在用户/会话结构可用时才记录。但行号不会那么好。

我们正在将大猩猩的部分用于网络事物,除此之外主要是标准库。

关于此的建议和想法?

1 个答案:

答案 0 :(得分:13)

由于滥用的可能性很高,因此无法在Go中访问当前goroutine的标识符。这看起来似乎很严苛,但这实际上保留了Go包生态系统的一个重要特性:如果你开始一个新的goroutine做某事并不重要。

即,对于函数F的任何方法:

F()

几乎完全等同于:

done := make(chan struct{})
go func() {
   defer close(done)
   F()
}
<-done

(“差不多”来自这样一个事实:如果F恐慌,恐慌 不会被原来的goroutine抓住。)

这也适用于日志记录 - 如果您使用的是当前的goroutine 推断当前用户,任何启动新goroutine的代码 如上所述将打破这种假设和你的记录 不包含预期的信息。

你需要传递某种背景。