log4go 打印日志 flush 问题

2015-11-26 11:18:37 +08:00
 wusuopuBUPT
使用 log4go 官方提供的 example 发现,指定了 Log 文件后,运行程序并不能把 log 打印到文件,在 stackoverflow 上发现答案: http://stackoverflow.com/questions/14252766/abnormal-behavior-of-log4go , 给出的解释是 log4go 用的是 channel 暂存日志,打印会另起一个 goroutine 进行,但是主 goroutine 退出太快时,负责打印日志的 goroutine 没机会把 channel 中的日志打印出来,导致日志丢失。

临时的解决办法: 在程序最后加上: time.Sleep(time.Second), sleep()调用会留给打印日志的 goroutine 执行的时间。

请问各位同学,有没有什么永久性的解决办法呢?
1633 次点击
所在节点    Go 编程语言
6 条回复
zhujinliang
2015-11-26 11:40:57 +08:00
解决这个问题…是个挺麻烦的事……
我自己写日志库时也遇到了这个问题
如果那个库没提供“等待退出”这样的方法的话,是没有办法的

你需要给负责打印日志工作的 goroutine 通过 channel 发送一个消息,让它主动退出,但如果传送日志的 channel 是个带缓冲带 channel 的话, goroutine 返回前还需要用 for...range 或者 for...select...default 把缓存中的日志处理完
hhkbp2
2015-11-26 13:29:16 +08:00
永久解决,不如换成这个吧
https://github.com/hhkbp2/go-logging
yougg
2015-11-26 14:40:37 +08:00
把异步写日志改成同步的, 如果你能接受性能损耗...
Comdex
2015-11-26 15:41:51 +08:00
换个库?
elgoog1970
2015-11-26 17:43:39 +08:00
ensonmj
2015-11-26 19:56:19 +08:00
最简单的改法,把 buffer 调成非缓冲的,就变成同步的了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/239039

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX