Spring Boot幾種啟動問題的解決方案
使用Spring Boot以來,遇到和解決過好幾次不同的專案啟動問題,大多數事故起於錯誤的配置和依賴。因此,本文用於彙總這些問題,以及提供相應的解決方案,幫助大家更快的定位和排除故障。
1. Unregistering JMX-exposed beans on shutdown
專案中沒有新增spring-boot-starter-web
模組依賴,在啟動 Application 執行過程中會出現這個錯誤。
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.5.11.RELEASE)
2018-05-02 18:32:49.445 INFO 33160 --- [ main] cn.mariojd.demo.DemoApplication : Starting DemoApplication on Mario with PID 33160 (started by jd in D:\IntelliJ IDEA\projects\test)
2018-05-02 18:32:49.451 INFO 33160 --- [ main] cn.mariojd.demo.DemoApplication : No active profile set, falling back to default profiles: default
2018-05-02 18:32:49.542 INFO 33160 --- [ main] s.c.a.AnnotationConfigApplicationContext : Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@17211155: startup date [Wed May 02 18:32:49 CST 2018]; root of context hierarchy
2018-05-02 18:32:50.115 INFO 33160 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup
2018-05-02 18:32:50.128 INFO 33160 --- [ main] cn.mariojd.demo.DemoApplication : Started DemoApplication in 1.01 seconds (JVM running for 1.83)
... end SpringApplication.run()
2018-05-02 18:32:50.129 INFO 33160 --- [ Thread-2] s.c.a.AnnotationConfigApplicationContext : Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@17211155: startup date [Wed May 02 18:32:49 CST 2018]; root of context hierarchy
2018-05-02 18:32:50.130 INFO 33160 --- [ Thread-2] o.s.j.e.a.AnnotationMBeanExporter : Unregistering JMX-exposed beans on shutdown
解決方案,引入spring-boot-starter-web模組
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
網上大多數的解決方案是通過新增spring-boot-starter-tomcat
依賴來解決,但實測證明此方法不可行。
2. Cannot determine embedded database driver class for database type NONE
專案中新增了spring-boot-starter-data-jpa
模組依賴,而且沒有配置資料來源連線資訊的情況下,啟動 Application 過程中會出現該錯誤,原因是Spring Boot在啟動時會自動注入資料來源和配置JPA。
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.5.11.RELEASE)
2018-05-02 19:49:13.640 INFO 37652 --- [ main] cn.mariojd.demo.DemoApplication : Starting DemoApplication on Mario with PID 37652 (started by jd in D:\IntelliJ IDEA\projects\test)
2018-05-02 19:49:13.643 INFO 37652 --- [ main] cn.mariojd.demo.DemoApplication : No active profile set, falling back to default profiles: default
2018-05-02 19:49:13.692 INFO 37652 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@62fdb4a6: startup date [Wed May 02 19:49:13 CST 2018]; root of context hierarchy
2018-05-02 19:49:15.150 INFO 37652 --- [ main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' of type [org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration$$EnhancerBySpringCGLIB$$4ad697b] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
2018-05-02 19:49:15.433 INFO 37652 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http)
2018-05-02 19:49:15.460 INFO 37652 --- [ main] o.apache.catalina.core.StandardService : Starting service [Tomcat]
2018-05-02 19:49:15.461 INFO 37652 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/8.5.29
2018-05-02 19:49:15.564 INFO 37652 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext
2018-05-02 19:49:15.564 INFO 37652 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 1876 ms
2018-05-02 19:49:15.679 INFO 37652 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/]
2018-05-02 19:49:15.682 INFO 37652 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'characterEncodingFilter' to: [/*]
2018-05-02 19:49:15.682 INFO 37652 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
2018-05-02 19:49:15.682 INFO 37652 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'httpPutFormContentFilter' to: [/*]
2018-05-02 19:49:15.683 INFO 37652 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'requestContextFilter' to: [/*]
2018-05-02 19:49:15.717 WARN 37652 --- [ main] ationConfigEmbeddedWebApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration': Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Tomcat.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.tomcat.jdbc.pool.DataSource]: Factory method 'dataSource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Cannot determine embedded database driver class for database type NONE. If you want an embedded database please put a supported one on the classpath. If you have database settings to be loaded from a particular profile you may need to active it (no profiles are currently active).
2018-05-02 19:49:15.719 INFO 37652 --- [ main] o.apache.catalina.core.StandardService : Stopping service [Tomcat]
2018-05-02 19:49:15.765 INFO 37652 --- [ main] utoConfigurationReportLoggingInitializer :
Error starting ApplicationContext. To display the auto-configuration report re-run your application with 'debug' enabled.
2018-05-02 19:49:15.791 ERROR 37652 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter :
***************************
APPLICATION FAILED TO START
***************************
Description:
Cannot determine embedded database driver class for database type NONE
Action:
If you want an embedded database please put a supported one on the classpath. If you have database settings to be loaded from a particular profile you may need to active it (no profiles are currently active).
Process finished with exit code 1
- 解決方案1,移除
spring-boot-starter-data-jpa
模組依賴; - 解決方案2,將啟動類註解
@SpringBootApplication
修改如下;
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class,DataSourceTransactionManagerAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
- 解決方案3,在配置檔案中新增資料庫連線資訊。
spring:
datasource:
url: xxx
username: xxx
password: xxx
相關文章
- 加快Spring Boot啟動的幾種方法 | baeldungSpring Boot
- spring boot 2.0 專案啟動就關閉問題解決Spring Boot
- spring security 問題解決方案Spring
- 盤點 Spring Boot 解決跨域請求的幾種方法Spring Boot跨域
- 解決angular+spring boot的跨域問題AngularSpring Boot跨域
- 跨域的幾種解決方案跨域
- Spring boot 解決跨域問題配置類Spring Boot跨域
- 前端解決跨域問題的8種方案前端跨域
- 高精度定位的幾種解決方案
- js 非同步的幾種解決方案JS非同步
- 7 種方案解決移動端1px邊框的問題
- spring-cloud-搭建Eureka出現內建tomcat無法啟動的問題解決方案SpringCloudTomcat
- Spring Boot 整合 Seata 解決分散式事務問題Spring Boot分散式
- spring-boot + jsonp 解決前端跨域問題SpringbootJSON前端跨域
- 解決Win2000 不能啟動的幾種方法
- 移動端滾動穿透問題解決方案穿透
- 解決ASM無法啟動問題ASM
- hbase啟動失敗問題解決
- mongodb啟動失敗問題解決MongoDB
- 幾種解決“藍芽不可用”問題的辦法藍芽
- PHP 併發場景的幾種解決方案PHP
- Spring Boot開啟的2種方式Spring Boot
- 移動端適配問題解決方案
- spring boot 註解物件的問題 待研究Spring Boot物件
- 四種方案解決ScrollView巢狀ListView問題View巢狀
- 適配移動端的問題以及解決方案
- 【前端詞典】滾動穿透問題的解決方案前端穿透
- 釋出或重啟線上服務時抖動問題解決方案
- 移動端滾動穿透問題完美解決方案穿透
- MFC軟體國際化的幾個問題及其解決方案
- Spring Boot啟動流程Spring Boot
- spring-boot啟動Springboot
- spring boot解決跨域訪問配置Spring Boot跨域
- NSTimer迴圈引用的幾種解決方案
- Linux啟動問題解決方法(轉)Linux
- iOS Unable to boot simulator的問題與解決iOSboot
- 解決Spring Boot無法跳轉jsp頁面問題Spring BootJS
- Spring Boot前後端分離專案Session問題解決Spring Boot後端Session