【发布时间】:2013-10-07 13:25:00
【问题描述】:
我正在修改我们用 golang 编写的小型 Web 应用程序的日志记录。由于外部要求,日志记录已被隔离在一个地方,因此我们以后可能会切换到 日志记录服务器。 (不是我的想法——我保证......)不过,我们现在能够记录常见的东西,比如日期/时间、行号、用户和消息,主要使用标准库的一部分和我们传递的用户/会话结构大约。
但是 - 问题来了 - 在较低级别的方法中,为了记录而传递会话只是为了获取用户名是一种浪费。所以我想找点别的东西来在日志文件中找到一个特定的请求。我确信有一些我没有想到的显而易见的事情。
目前的想法:
- Java 日志框架可以打印出线程 ID,这在这种情况下也足够了。只是它在golang中被称为别的东西吗?
- 以某种方式使用户/会话结构可以全局访问。 (除非有线程用作查找键,否则仍需要传递会话 ID。回到想法 1。)
- 无论如何都要放弃并传递用户/会话结构。
- 不要在最低级别记录错误,但仅在用户/会话结构可用时才记录。不过行号不会那么好。
我们将部分 gorilla 用于网络事物,除此之外主要是标准库。
对此有何建议和想法?
【问题讨论】:
-
你没有真正的选择:你必须在某种程度上将引用传递给你的用户(显式地或通过闭包),没有 goroutine id 这样的东西。
-
您是否考虑过使用类似 expvar 的东西? (golang.org/pkg/expvar) “包 expvar 为公共变量提供标准化接口,例如服务器中的操作计数器。它通过 HTTP 以 JSON 格式在 /debug/vars 公开这些变量。”可以帮助获得全球可访问的统计数据。
-
不——有趣的包。不知道它对我有什么帮助 - 我仍然需要一些东西来解决这个问题。某种钥匙?对吗?