如下图所示,运行的jar 包和 log4j 的配置文件放在同一个目录,jar包内没有任何配置文件:
在spring boot 框架的 main 方法中,通过下面这种方式,加载jar 包外的log4j配置文件
log4j配置文件的输出位置如下:
运行java -jar gf-mfile.jar 之后,控制台有info 日志信息,如下图:
系统也能够创建 micofile.log 日志文件,但是,文件为null,0字节,里面没有任何数据,info 日志信息没有写入文件中,如下图:
问题:
如果,我将log4j配置文件 打到jar 包中,如下图:
执行jar,日志文件是能够生成日志信息的。我把log4j配置文件,放到和jar 包同级目录就只创建日志文件不写入日志信息了。
为什么配置文件放到jar包外,日志文件中没有内容? 请大神赐教,感激不尽……
(本人推测,是否是main方法中的读取,log4j 配置文件的代码有问题,如果是这样应该怎么修改?)
还需要看你的运行参数,特别是 classpath 参数,是否把这个包外的配置文件包含到了 classpath 当中。