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