spring boot啟動(dòng)出現(xiàn)Unable to start ServletWebServerApplicationContext due to missing ServletWebServer錯(cuò)誤解決
報(bào)錯(cuò)原因
今天拉下了一個(gè)新的spring boot工程,啟動(dòng)時(shí)出現(xiàn)了Unable to start web server; nested exception is org.springframework.context.ApplicationContextException: Unable to start ServletWebServerApplicationContext due to missing ServletWebServerFactory bean.這個(gè)異常。在網(wǎng)上搜索這個(gè)錯(cuò)誤,有幾種說(shuō)法。
說(shuō)法一:是因?yàn)槿鄙僖粋€(gè)spring-boot-starter-web依賴(lài)。檢查pom文件,發(fā)現(xiàn)這個(gè)依賴(lài)已經(jīng)被引入了,所以不是這個(gè)問(wèn)題。
說(shuō)法二:是沒(méi)有添加@EnableAutoConfiguration這個(gè)注解。但是在啟動(dòng)類(lèi)中已經(jīng)有@SpringBootApplication這個(gè)注解了,這個(gè)注解已經(jīng)包含了@EnableAutoConfiguration注解,所以也不是這個(gè)原因,那么到底是什么原因呢。
發(fā)現(xiàn)問(wèn)題
可見(jiàn)是在調(diào)用getWebServerFactory()方法時(shí)候發(fā)生錯(cuò)誤,沒(méi)有找到ServletWebServerFactory這個(gè)bean,說(shuō)明在sping容器啟動(dòng)時(shí)沒(méi)有將其注冊(cè)進(jìn)去,缺少相關(guān)依賴(lài)。沒(méi)有對(duì)應(yīng)的servelt容器,工程當(dāng)然也就啟動(dòng)不起來(lái)。這里多講一下,springboot工程會(huì)通過(guò)@EnableAutoConfiguration這個(gè)注解去拉去默認(rèn)配置,該注解通過(guò)@Import注解導(dǎo)入了AutoConfigurationImportSelector類(lèi)。其實(shí)這個(gè)類(lèi),就是導(dǎo)入通過(guò)加載配置文件,加載了很多工廠(chǎng)方法的配置類(lèi)。最終會(huì)加載 META-INF/spring.factories這些文件,通過(guò)這些文件完成自動(dòng)裝配。@Import注解加載了tomcat,jetty,undertow三個(gè)web服務(wù)器的配置類(lèi)。由于沒(méi)有導(dǎo)入jetty和undertow的相關(guān)jar包,這兩個(gè)類(lèi)實(shí)例的不會(huì)真正的加載。到這里分析,為什么會(huì)缺少相應(yīng)的servlet容器?springboot不默認(rèn)加載了tomcat容器嗎,因?yàn)閠omcat的相關(guān)jar包已經(jīng)在spring-boot-starter-web中引入了,按照之前我們的分析,實(shí)際上被加載的容器應(yīng)該是tomcat,為什么還會(huì)找不到呢?
那么此時(shí)我們要分析一下整個(gè)工程的依賴(lài)情況,看tomcat相關(guān)jar包是否被真實(shí)的引入。使用mvn dependency:tree命令,對(duì)工程進(jìn)行依賴(lài)分析,定位到居然無(wú)tomcat相關(guān)依賴(lài)。
此時(shí)可以發(fā)現(xiàn)pom.xml文件中,居然把tomcat排除了,那我排除的去掉即可:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency>
解決方法
去掉排除設(shè)置:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <!-- <exclusions>--> <!-- <exclusion>--> <!-- <groupId>org.springframework.boot</groupId>--> <!-- <artifactId>spring-boot-starter-tomcat</artifactId>--> <!-- </exclusion>--> <!-- </exclusions>--> </dependency>
將pom中的<exclusions></exclusions>或者整個(gè)注釋掉,重新編譯測(cè)試和運(yùn)行。重新啟動(dòng)工程,啟動(dòng)成功。
到此這篇關(guān)于spring boot啟動(dòng)出現(xiàn)Unable to start ServletWebServerApplicationContext due to missing ServletWebServer錯(cuò)誤解決的文章就介紹到這了,更多相關(guān)spring boot啟動(dòng)出現(xiàn)錯(cuò)誤解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無(wú)法加載主類(lèi)的三種解決方法
- SpringBoot 啟動(dòng)報(bào)錯(cuò)Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379問(wèn)題的解決方案
- 查看本地啟動(dòng)SpringBoot的本地端口號(hào)的幾種方式
- SpringBoot中@Scheduled實(shí)現(xiàn)服務(wù)啟動(dòng)時(shí)執(zhí)行一次
- SpringBoot應(yīng)用啟動(dòng)慢的原因分析及優(yōu)化方法
- Spring boot啟動(dòng)原理及相關(guān)組件整理
相關(guān)文章
SpringQuartz定時(shí)任務(wù)核心組件JobDetail與Trigger配置
Spring框架與Quartz調(diào)度器的集成提供了強(qiáng)大而靈活的定時(shí)任務(wù)解決方案,本文主要介紹了SpringQuartz定時(shí)任務(wù)核心組件JobDetail與Trigger配置,具有一定的參考價(jià)值,感興趣的可以了解一下2025-04-04JAVA Stack詳細(xì)介紹和示例學(xué)習(xí)
JAVA Stack是棧。它的特性是:先進(jìn)后出(FILO, First In Last Out)。2013-11-11Java實(shí)現(xiàn)動(dòng)態(tài)代理
本文給大家介紹的是java使用動(dòng)態(tài)代理類(lèi)實(shí)現(xiàn)動(dòng)態(tài)代理的方法和示例,這里推薦給大家,有需要的小伙伴參考下吧2015-02-02Java過(guò)濾器如何解決存儲(chǔ)型xss攻擊問(wèn)題
這篇文章主要介紹了Java過(guò)濾器如何解決存儲(chǔ)型xss攻擊問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05SpringBoot自帶模板引擎Thymeleaf使用示例詳解
Thymeleaf是一款用于渲染XML/HTML5內(nèi)容的模板引擎,類(lèi)似JSP,它可以輕易的與SpringMVC等Web框架進(jìn)行集成作為Web應(yīng)用的模板引擎,本文給大家介紹SpringBoot自帶模板引擎Thymeleaf使用示例,感興趣的朋友一起看看吧2023-12-12