持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第1天,点击查看活动详情
文章首发于个人博客:SpringBoot启动卡在初始画面 (javalover.cc)
问题描述
今天从远程拉了一个Spring Boot项目,启动时遇到一个很奇怪的问题:启动项目没有报错,但是就是卡在下面这个画面不动;
原因分析
- 可能是程序有问题,但是我在主程序启动的地方加上try catch进行异常捕获,没发现异常;
- 可能是打了断点,并以debug方式启动,结果卡在断点处,但是我没有打断点
- 后来查了下日志打印的相关配置:logback.xml,结果发现根本没有配置 在控制台输出日志。。。(如果配置了但是
level为error,也是同样的情景)
下面是日志配置logback.xml:
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="10 seconds">
<contextName>logback</contextName>
<springProperty scope="context" name="appName" source="spring.application.name"/>
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--省略-->
</appender>
<appender name="INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--省略-->
</appender>
<root level="INFO">
<appender-ref ref="ERROR_FILE" />
<appender-ref ref="INFO_FILE" />
</root>
</configuration>
可以看到,这里就配置了两个appender,分别是错误文件error_file和信息文件info_file;
就是没有配置控制台输出。
解决办法
解决办法就是修改logback.xml配置,增加一个控制台输出的appender:
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="debug">
<appender-ref ref="STDOUT" />
</root>
</configuration>
完整的日志配置logback.xml如下:
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="10 seconds">
<contextName>logback</contextName>
<springProperty scope="context" name="appName" source="spring.application.name"/>
<property name="log.path" value="./log/${appName}" />
<!-- 控制台输出 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/error.log</file>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${log.path}/error/log-error-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>2MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>error</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<appender name="INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/info.log</file>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${log.path}/info/log-info-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>2MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>info</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<root level="INFO">
<appender-ref ref="ERROR_FILE" />
<appender-ref ref="INFO_FILE" />
<appender-ref ref="STDOUT" />
</root>
</configuration>
总结
Spring Boot项目卡在启动界面的原因有很多,现列出如下几种:
- 控制台输出日志没配置或者level为error;这种就是上面介绍的情景,解决办法就是配置控制台输出,或者不配置直接运行(但总感觉少点东西);
- 程序异常,但是没有被捕获;可在主程序中加上 try-catch 进行异常捕获,来分析问题;
- 打了断点,并以debug方式启动,结果卡在断点处;如果是这种,解决办法就很简单了,删除断点即可;