Spring bootプロジェクトtomcatで起動する問題
7600 ワード
問題の説明
今日spring-bootプロジェクトを使用している間に、打ったwarをtomcatに置いて起動したとき、エラーを報告しました.情報は以下の通りです.
もんだいぶんせき
エラーの原因として、E m b e d d e d e d e d S o r t o n a i n erCustomizerBeanPostProcessor.getCustomizers()というメソッドは、呼び出し時に空のポインタプログラムを次のように報告します.
このクラスはBeanPostProcessorの実装クラスであり、空のポインタはthis.applicationContext.getBeansOfType(E m b e d d d d e d S v e r t ContainerCustomizer.class,false,false).values()に報告され、values()の呼び出し者は空である.すなわち、applicationContextはgetBeanOfTypeメソッドによってEmbeddedServiceletContainerCustomizerインスタンスが見つからない.しかし、私たちの目的は埋め込みtomcatを望んでいないことであり、プロジェクトpomファイルはspring埋め込みtomcatを排除しており、以下のように構成されています.
問題解決
その後mavenの依存に問題が発見され、spring-boot-dependenciesのバージョンは1.5.4と制定されたが、実際のspring-bootのバージョンは1.5.2であり、spring-boot-starter:1.5.4とspring-boot-web 1.5.4とは一致しなかった.その後spring-boot-dependenciesのバージョンを1.5.2に統一した後、不一致な問題が解決し、tomcatも正常に起動した.
後述:バックグラウンドでは、spring-bootのバージョン番号を宣言する優先度の高い場所があることがわかりました.
Spring-bootのGitHubでも似たような問題に遭遇したことがある人がいますが、ここにリンクしてください.
今日spring-bootプロジェクトを使用している間に、打ったwarをtomcatに置いて起動したとき、エラーを報告しました.情報は以下の通りです.
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'tomcatEmbeddedServletContainerFactory' defined in class path resource [org/springframework/boot/autoconfigure/web/EmbeddedServletContainerAutoConfiguration$EmbeddedTomcat.class]: Initialization of bean failed; nested exception is java.lang.NullPointerException
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:564)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:761)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543)
at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122)
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:737)
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:370)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:314)
at org.springframework.boot.web.support.SpringBootServletInitializer.run(SpringBootServletInitializer.java:151)
at org.springframework.boot.web.support.SpringBootServletInitializer.createRootApplicationContext(SpringBootServletInitializer.java:131)
at org.springframework.boot.web.support.SpringBootServletInitializer.onStartup(SpringBootServletInitializer.java:86)
at org.springframework.web.SpringServletContainerInitializer.onStartup(SpringServletContainerInitializer.java:169)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5196)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:952)
at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1823)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.NullPointerException: null
at org.springframework.boot.context.embedded.EmbeddedServletContainerCustomizerBeanPostProcessor.getCustomizers(EmbeddedServletContainerCustomizerBeanPostProcessor.java:77)
at org.springframework.boot.context.embedded.EmbeddedServletContainerCustomizerBeanPostProcessor.postProcessBeforeInitialization(EmbeddedServletContainerCustomizerBeanPostProcessor.java:67)
at org.springframework.boot.context.embedded.EmbeddedServletContainerCustomizerBeanPostProcessor.postProcessBeforeInitialization(EmbeddedServletContainerCustomizerBeanPostProcessor.java:54)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:409)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1620)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:555)
... 28 common frames omitted
もんだいぶんせき
エラーの原因として、E m b e d d e d e d e d S o r t o n a i n erCustomizerBeanPostProcessor.getCustomizers()というメソッドは、呼び出し時に空のポインタプログラムを次のように報告します.
private Collection getCustomizers() {
if (this.customizers == null) {
// Look up does not include the parent context
this.customizers = new ArrayList(
this.applicationContext
.getBeansOfType(EmbeddedServletContainerCustomizer.class,
false, false)
.values());
Collections.sort(this.customizers, AnnotationAwareOrderComparator.INSTANCE);
this.customizers = Collections.unmodifiableList(this.customizers);
}
return this.customizers;
}
このクラスはBeanPostProcessorの実装クラスであり、空のポインタはthis.applicationContext.getBeansOfType(E m b e d d d d e d S v e r t ContainerCustomizer.class,false,false).values()に報告され、values()の呼び出し者は空である.すなわち、applicationContextはgetBeanOfTypeメソッドによってEmbeddedServiceletContainerCustomizerインスタンスが見つからない.しかし、私たちの目的は埋め込みtomcatを望んでいないことであり、プロジェクトpomファイルはspring埋め込みtomcatを排除しており、以下のように構成されています.
org.springframework.boot
spring-boot-starter
org.apache.tomcat
tomcat-jdbc
org.springframework.boot
spring-boot-starter-web
org.apache.tomcat
tomcat-jdbc
org.springframework.boot
spring-boot-starter-tomcat
問題解決
その後mavenの依存に問題が発見され、spring-boot-dependenciesのバージョンは1.5.4と制定されたが、実際のspring-bootのバージョンは1.5.2であり、spring-boot-starter:1.5.4とspring-boot-web 1.5.4とは一致しなかった.その後spring-boot-dependenciesのバージョンを1.5.2に統一した後、不一致な問題が解決し、tomcatも正常に起動した.
org.springframework.boot
spring-boot-dependencies
1.5.4.RELEASE
pom
import
後述:バックグラウンドでは、spring-bootのバージョン番号を宣言する優先度の高い場所があることがわかりました.
Spring-bootのGitHubでも似たような問題に遭遇したことがある人がいますが、ここにリンクしてください.