如何在 Spring Boot 应用程序中以编程方式配置日志记录?
使用 xml 或属性文件对我的需要不够灵活。
更新:我想实现这样的目标:
@Value("${logging.level.root}")
private String loggingLevelRoot;
@Value("${logging.level.myApp}")
private String loggingLevelMyApp;
@Value("${logging.file}")
private boolean fileAppenderEnabled;
....
setLevel(Logger.ROOT_LOGGER_NAME, Level.toLevel(loggingLevelRoot)));
setLevel("com.myapp", Level.toLevel(loggingLevelMyApp)));
setLevel("org.springframework", Level.WARN);
setLevel("org.apache.coyote", Level.INFO);
setLevel("org.apache.catalina", Level.INFO);
setLevel("org.apache.catalina.startup.DigesterFactory", Level.ERROR);
setLevel("org.apache.catalina.util.LifecycleMBeanBase", Level.ERROR);
Logger logger = (Logger) LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
logger.addAppender(createConsoleAppender());
if (fileAppenderEnabled) {
logger.addAppender(createFileAppender());
}
我拥有的每个环境是:
- logging.level.root=[信息,调试,..]
- logging.level.myApp=[信息,调试,..]
- 日志记录文件=[真 | 错误的]
没有我真的不想处理的 XML、Groovy 和其他格式的重复。
归根结底,这实际上是为了实现与 Spring JavaConfig 为 bean 所做的相同的日志记录灵活性。XML 或其他文件格式太静态了,需要太多重复,并且与应用程序的其余配置集成得不够好。
为什么日志记录的配置应该与任何其他 bean 或服务不同?这没有道理。