我试图让Spring Boot与Logback一起工作,并且遇到了一个我无法弄清楚的错误/问题。Spring引导应用程序遇到logback.groovy配置文件的问题
重现此问题的全部,我创建了一个GitHub的Spring Boot Example repo,但本质上,这是我application.yml
:
logging:
config: 'logback.groovy'
server:
port: 9200
error:
whitelabel:
enabled: false
而且我logback.groovy
:
statusListener(OnConsoleStatusListener)
def LOG_PATH = '/opt/springbootexample/logs/springbootexample'
appender('CONSOLE', ConsoleAppender) {
encoder(PatternLayoutEncoder) {
pattern = '%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n'
}
}
appender('FILE', FileAppender) {
file = "${LOG_PATH}.log"
encoder(PatternLayoutEncoder) {
pattern = '%msg%n'
outputPatternAsHeader = true
}
}
appender('ROLLING', RollingFileAppender) {
encoder(PatternLayoutEncoder) {
Pattern = '%d %level %thread %mdc %logger - %m%n'
}
rollingPolicy(TimeBasedRollingPolicy) {
fileNamePattern = "${LOG_PATH}-%d{yyyy-MM}.zip"
maxHistory = 30
totalSizeCap = '1KB'
}
}
root(INFO, ["CONSOLE", "ROLLING"])
我已确认那/opt/springbootexample/logs
存在我跑chmod -R 777 /opt/springbootexample
所以我的Spring Boot应用程序应该没有问题在那里创建日志文件并写入他们。
当我在本地运行应用程序时,我没有得到错误/异常/警告;在控制台输出中一切看起来都很完美。然后我启动一个浏览器并指向http://localhost:9200
,它应该返回一个简单的虚拟消息,但是没有任何反应。更糟糕的是,控制台中没有任何事情发生。
唯一的线索是,我已经关闭了该应用程序后,如果我去/opt/springbootexample/logs/springbootexample.log
,其内容是:
#logback.classic pattern: %msg%n
告诉我,也许有一些配置错误在我logback.groovy
的FileAppender
也许?任何想法/想法?