程序运行,初始化日志库(日志信息写入日志库内部通道中,启动一个协程从通道过去写入文件中),接着解析配置文件,如果解析失败,程序将退出;但退出之前要报错记录记录到日志中,目前没有好的思路,请帮忙看看呢?
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-03-16 21:15:42 +08:00
把你的日志配置和整体配置分开就行。启动日志程序,日志分类型,不是写个 error 类型的日志就行了吗?
你的代码应该在本地测试的时候保证配置可用吧。 当然你也可以远程同步配置文件,这个时候就可能会发送这种情况。 定时收集你的机器上 error 日志,特别是项目刚刚上线。 |
2
visitant 2020-03-16 21:33:06 +08:00
日志库一般都有提供 flush 接口吧,调用一下就可以了.
|
3
ropon OP @cabing
嗯,日志分级别,比如一个小项目,需求记录程序运行过程中日志,目前问题就是主程序退出,日志还没记录 |
4
useben 2020-03-16 22:55:41 +08:00
注册信号,退出触发信号,然后 flush 一下落盘就行
|
6
Hades300 2020-03-19 23:56:35 +08:00 via Android
自己封装一个 exit,写个循环,等 chan 里的元素数量为 0 就可退出了。
|
7
Hades300 2020-03-20 00:02:51 +08:00 via Android
好像有点欠考虑,不知道你说的协程是不是 goruntine,不如加个标志元素,在写文件的 runtine 里面加个判断。让这个 runtine 来结束
|
9
index90 2020-03-20 16:36:21 +08:00
简单来说,就是你的主线程需要等待日志写文件进程结束后才能结束。
写线程加个 wait chan 就好了 |