此文章记录一次spring boot通过main 方法启动无法成功的问题
Unregistering JMX-exposed beans on shutdown
问题如下,因为已经解决用的别人的截图但是效果是一样的
百度了一圈都说tomcat没有配置,但实际xml有如下配置
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </dependency>
问题:eclipse maven自动下jar包时下载的不全,有部分文件丢失,但是控制台并没有发出任何 classNotFound提示
解决:C:\Users\Administrator\.m2\repository\org\apache\tomcat\embed
讲该目录下的所有文件删除,然后右键项目maven-> update project,
其他同类发现classNotFound也可以通过寻找对应jar包在本地仓库位置,使用相同操作进行解决
补充知识:springboot 设置web和非web启动
springBoot区分web和非web项目
老版本:
#server config #web_environment是否是web项目 spring.main.web_environment=true #是否加载springboot banner spring.main.show_banner=false
现版本:
#server config #是否设定web应用,none-非web,servlet-web应用 spring.main.web-application-type=servlet #加载springboot banner的方式:off-关闭,console-控制台,log-日志 spring.main.banner-mode=off
WebApplicationType原理:
public SpringApplication(ResourceLoader resourceLoader, Class<?>... primarySources) { this.resourceLoader = resourceLoader; Assert.notNull(primarySources, "PrimarySources must not be null"); this.primarySources = new LinkedHashSet<>(Arrays.asList(primarySources)); this.webApplicationType = deduceWebApplicationType(); setInitializers((Collection) getSpringFactoriesInstances(ApplicationContextInitializer.class)); setListeners((Collection) getSpringFactoriesInstances(ApplicationListener.class)); this.mainApplicationClass = deduceMainApplicationClass(); }
deduceWebApplicationType()推断当前环境是哪种Web环境(Servlet、Reactive),或者不是Web环境,判断逻辑为Classpath是够有以下类:
存在org.springframework.web.reactive.DispatcherHandler且不存在org.springframework.web.servlet.DispatcherServlet为WebApplicationType.REACTIVE;
同时存在javax.servlet.Servlet、org.springframework.web.context.ConfigurableWebApplicationContext 为WebApplicationType.SERVLET;
否则为 WebApplicationType.NONE
在这里this.webApplicationType = WebApplicationType.SERVLET;
所谓的banner就是控制台打印的一堆线组成的spring
以上这篇解决Spring boot 嵌入的tomcat不启动问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自学编程网。
- 本文固定链接: https://zxbcw.cn/post/197191/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)