[英]Spring boot - Docker logs
我有一个在 docker 容器内运行的 spring boot java 应用程序。 我在应用程序中配置了 logback。 我在哪里可以访问生成的日志? 配置的路径是:
<property name="LOG_PATH" value="logs"/>
我目前正在使用以下方法检查日志: docker logs containerName --follow 但是此命令返回上次启动应用程序时的当前日志。 我如何检查滚动日志或存档的日志。
有没有办法为 logback 日志创建卷?
我使用以下方式:在 logback.xml 中:
<?xml version="1.0" encoding="UTF-8"?>
<property name="LOG_PATH" value="logs"/>
<timestamp key="currentTimestamp" datePattern="yyyy-MM-dd'_'HH"/>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>
%d{dd-MM-yyyy HH:mm:ss.SSS} %magenta([%thread]) %highlight(%-5level) %logger.%M\(%line\) - %msg%n
</pattern>
</encoder>
</appender>
<appender name="SAVE-TO-FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_PATH}/appName.log</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>
%d{dd-MM-yyyy HH:mm:ss.SSS} [%thread] %-5level %logger{36}.%M - %msg%n
</Pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!-- the rollover occurs when the active log file reaches the maximum file size before the end of the time period. -->
<!-- The rollover period is inferred from the smallest date unit value of fileNamePattern -->
<!-- each file should be at most [maxFileSize], keep [maxHistory] days worth of history, but at most [totalSizeCap] -->
<maxFileSize>100MB</maxFileSize>
<fileNamePattern>
${LOG_PATH}/archived/appName.%d{yyyy-MM-dd}.%i.log
</fileNamePattern>
<maxHistory>30</maxHistory>
<totalSizeCap>1GB</totalSizeCap>
</rollingPolicy>
</appender>
<root level="INFO">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</root>
在 docker 中运行:
docker run --network name-network --restart=unless-stopped --name name-java-container
--hostname valueOfHostname -d -p 8080:8080 \
-v /data/nameFolderForLogs:/logs \
imageName
尝试使用。实现你的文件追加器
<configuration>
...
<property name="LOG_PATH" value=/var/app>
...
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_PATH}/spring.log</file>
...
</appender>
</configuration>
然后,您可以运行下一个命令:
docker exec -it containerName cat /var/app/spring.log > $HOME/spring.log
或者使用(docker run ... -v "$HOME/app:/var/app")
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.