程序记录日志疑惑

2020-03-16 21:11:59 +08:00
 ropon

程序运行,初始化日志库(日志信息写入日志库内部通道中,启动一个协程从通道过去写入文件中),接着解析配置文件,如果解析失败,程序将退出;但退出之前要报错记录记录到日志中,目前没有好的思路,请帮忙看看呢?

2256 次点击
所在节点    Go 编程语言
9 条回复
cabing
2020-03-16 21:15:42 +08:00
把你的日志配置和整体配置分开就行。启动日志程序,日志分类型,不是写个 error 类型的日志就行了吗?

你的代码应该在本地测试的时候保证配置可用吧。

当然你也可以远程同步配置文件,这个时候就可能会发送这种情况。

定时收集你的机器上 error 日志,特别是项目刚刚上线。
visitant
2020-03-16 21:33:06 +08:00
日志库一般都有提供 flush 接口吧,调用一下就可以了.
ropon
2020-03-16 21:36:22 +08:00
@cabing
嗯,日志分级别,比如一个小项目,需求记录程序运行过程中日志,目前问题就是主程序退出,日志还没记录
useben
2020-03-16 22:55:41 +08:00
注册信号,退出触发信号,然后 flush 一下落盘就行
cabing
2020-03-17 10:17:23 +08:00
@useben 对,退出时 defer 关闭下。
Hades300
2020-03-19 23:56:35 +08:00
自己封装一个 exit,写个循环,等 chan 里的元素数量为 0 就可退出了。
Hades300
2020-03-20 00:02:51 +08:00
好像有点欠考虑,不知道你说的协程是不是 goruntine,不如加个标志元素,在写文件的 runtine 里面加个判断。让这个 runtine 来结束
ropon
2020-03-20 12:40:43 +08:00
@Hades300 是的,主要疑惑,已添加附言
index90
2020-03-20 16:36:21 +08:00
简单来说,就是你的主线程需要等待日志写文件进程结束后才能结束。
写线程加个 wait chan 就好了

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

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

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

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

© 2021 V2EX