程序运行,初始化日志库(日志信息写入日志库内部通道中,启动一个协程从通道过去写入文件中),接着解析配置文件,如果解析失败,程序将退出;但退出之前要报错记录记录到日志中,目前没有好的思路,请帮忙看看呢?
func main() {
//初始化日志
logger.InitLog()
defer logger.Close()
//是否自定义配置文件名
confName := tools.GetArg()
//初始化解析库
parseconf.InitConf(confName)
...
//并记录错误日志并退出
if err != nil {
logger.ErrorExit(err)
}
//记录正常日志
logger.Info("正常日志信息")
}
日志库
将日志信息写入日志库内部通道,再启动一个goroutine从通道获取逐条写入文件中
疑惑
1
cabing 2020 年 3 月 16 日
把你的日志配置和整体配置分开就行。启动日志程序,日志分类型,不是写个 error 类型的日志就行了吗?
你的代码应该在本地测试的时候保证配置可用吧。 当然你也可以远程同步配置文件,这个时候就可能会发送这种情况。 定时收集你的机器上 error 日志,特别是项目刚刚上线。 |
2
visitant 2020 年 3 月 16 日
日志库一般都有提供 flush 接口吧,调用一下就可以了.
|
4
useben 2020 年 3 月 16 日
注册信号,退出触发信号,然后 flush 一下落盘就行
|
6
Hades300 2020 年 3 月 19 日 via Android
自己封装一个 exit,写个循环,等 chan 里的元素数量为 0 就可退出了。
|
7
Hades300 2020 年 3 月 20 日 via Android
好像有点欠考虑,不知道你说的协程是不是 goruntine,不如加个标志元素,在写文件的 runtine 里面加个判断。让这个 runtine 来结束
|
9
index90 2020 年 3 月 20 日
简单来说,就是你的主线程需要等待日志写文件进程结束后才能结束。
写线程加个 wait chan 就好了 |