spring boot 2 的日志文件没能写出来的解决思路方法

要作日志操作,先需配置依赖:


    org.springframework.boot
    spring-boot-starter-logging
    true


然后简单的写一个打印日志的单元测试类:

import org.junit.Test;
//import org.junit.platform.commons.logging.Logger;
//import org.junit.platform.commons.logging.LoggerFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;


@RunWith(SpringRunner.class)
@SpringBootTest
public class LoggerTests {

    Logger logger= LoggerFactory.getLogger(getClass());

    @Test
    public void contextLoads(){
        //System.out.println("println test...");

        logger.trace("logger.trace test...");
        logger.debug("logger.debug test...");
        logger.info("logger.info test...");
        logger.warn("logger.warn test...");
        logger.error("logger.error test...");
    }
}
此时直接运行测试,控制台是可以看到

logger.info("logger.info test..."); 
logger.warn("logger.warn test..."); 
logger.error("logger.error test...");

这三个方法的输出结果的。(备注:默认不配置时,控制台输出的优先级是从logger.info开启的,所以trace和debug看不到。要想全看到五个,在application.properties文件中使用logging.level.com.xxxx=trace来实现)

到这里,可能你会想到它是不是会自动保存成了日志文件在硬盘中吧。当然答案是否定的。
因为默认是不开启写文件的,需要配置指定路径文件才会写。那么,可以这么配:在application.properties文件中,写上:
​​​​​​​logging.file.name=testlog.log
然后,运行测试,会自动生成了testlog.log文件在项目下的根目录中,并且文件中会记录了控制台输出的日志。

经验:如果你是用过一些旧版本,配置时可能会用
​​​​​​​logging.file=testlog.log

来配置,这样会发现没有日志文件产生出来,且没达到预期效果也没有报错。而需将​​​​​​​​​​​​​​logging.file改成logging.file.name才可以完成。

解决思路:不同的语言、框架、应用版本,如发现明明觉得所学的语法正确,但运行效果就是不达到,那么可能是版本升级后,原语法与新语法不同引起,需要注意查证正确用法再使用。

吐一吐心声:底层开发人员对底层框架的升级,或为了一些完美,或是考虑不周的改动,会给应用开发人员带来多些坑要填了。所以,底层的,公共的、基础的程序版本的开发与升级,都需三思而后行,要为使用者多着想一下,多综合考量才动。且最好是一开始就多进行命名规则规范设计,避免或减少后期命名的改动升级。

你可能感兴趣的:(CODE,spring,boot,java,后端)