spring-boot应用程序在启动时不会启动docker [英] Spring-boot application wont boot at startup inside docker

查看:352
本文介绍了spring-boot应用程序在启动时不会启动docker的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在Docker容器中运行一个简单的spring-boot应用程序。在启动时,不管是开始使用 java -jar MY_JAR.jar 还是 mvn spring-boot:run 应用程序将始终挂起以下几点:

  2014-12-22 23:26:58.957 INFO 1 --- [ost-startStop-1] osbcembedded.FilterRegistrationBean:映射过滤器:'hiddenHttpMethodFilter'到:[/ *] 

即使在容器内运行,我只能在DigitalOcean(1CPU,1GB MEM)的Ubuntu 14.04盒中重现。在我的本地机器(mac)上,一切都运行正常。



Dockerfile:

  FROM java:8 
添加目标/ MY_SERVICE-1.0-SNAPSHOT.jar /data/svc.jar
EXPOSE 8080
CMD [java -jar,/data/svc.jar]

尝试




  • 给JVM更多内存(占总机器的75%)

  • 安装已建立这里

  • 每个其他版本的java我都可以得到我的手



任何建议?



感谢任何帮助。



整个日志(以-debug开头):

  [忽略文字] 

:: Spring Boot ::(v1.1.10.RELEASE)

2014-12-22 19:22:58.375 INFO 20816 --- [main] com.spectrom .uploadService.Main:使用PID 20816(/root/spectrom-upload-service/target/upload-service-1.0-SNAPSHOT.jar以root身份启动/ root / spectrom-upload-service)启动光谱服务
$ b 2014-12-22 19:22:58.392 DEBUG 20816 --- [main] osboot.SpringApplication:加载源类com.spectrom.uploadService.Main
2014-12-22 19:22:58.671 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:Skipped config file'file:./ config / application.yaml'resource not found
2014-12-22 19:22:58.673 DEBUG 20816 --- [main] osbcc ConfigFileApplicationListener:Skipped config file'file:./ config / application.properties'resource not found
2014-12-22 19:22:58.674 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:Skipped config file'file: ./config/application.yml'资源未找到
2014-12-22 19:22:58.675 DEBUG 20816 --- [main] osbccConfigFileApplic ationListener:跳过的配置文件'file:./ application.yaml'资源未找到
2014-12-22 19:22:58.675 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:Skipped config file'file:./ application.properties'resource not found
2014-12-22 19:22:58.676 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:Skipped config file'file:./ application.yml'resource not found
2014-12-22 19:22:58.677 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:跳过的配置文件'classpath:/config/application.yaml'资源未找到
2014-12-22 19:22 :58.678 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:跳过的配置文件'classpath:/config/application.properties'资源未找到
2014-12-22 19:22:58.679 DEBUG 20816 --- [main ] osbccConfigFileApplicationListener:跳过的配置文件'classpath:/config/application.yml'资源不是und
2014-12-22 19:22:58.679 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:跳过的配置文件'classpath:/application.yaml'资源未找到
2014-12-22 19 :22:58.680 DEBUG 20816 --- [main] osbccConfigFileApplicationListener:加载的配置文件'classpath:/application.properties'
2014-12-22 19:22:58.681 DEBUG 20816 --- [main] osbccConfigFileApplicationListener :跳过配置文件'classpath:/application.yml'资源未找到
2014-12-22 19:22:58.693 INFO 20816 --- [main] ationConfigEmbeddedWebApplicationContext:刷新org.springframework.boot.context.embedded。 AnnotationConfigEmbeddedWebApplicationContext @ ddd51a7:启动日期[星期一12月22日19:22:58 EST 2014];根本的上下文层次
2014-12-22 19:22:58.708 DEBUG 20816 --- [main] ationConfigEmbeddedWebApplicationContext:Bean factory for org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7:org.springframework.beans .factory.support.DefaultListableBeanFactory @ 47649f10:定义beans [org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation。 internalCommonAnnotationProcessor,主];工厂层次结构
2014-12-22 19:23:00.964 INFO 20816 --- [main] o.s.b.f.s.DefaultListableBeanFactory:覆盖bean'beanNameViewResolver'的bean定义:replace [Root bean:class [null];范围=;抽象= FALSE; lazyInit = FALSE; autowireMode = 3; dependencyCheck = 0; autowireCandidate = TRUE;初级= FALSE; factoryBeanName = org.springframework.boot.autoconfigure.web.ErrorMvcAutoConfiguration $ WhitelabelErrorViewConfiguration; factoryMethodName = beanNameViewResolver; initMethodName = NULL; destroyMethodName =(推断);在[root bean:class [null])中的类路径资源[org / springframework / boot / autoconfigure / web / ErrorMvcAutoConfiguration $ WhitelabelErrorViewConfiguration.class]]中定义。范围=;抽象= FALSE; lazyInit = FALSE; autowireMode = 3; dependencyCheck = 0; autowireCandidate = TRUE;初级= FALSE; factoryBeanName = org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration $ WebMvcAutoConfigurationAdapter; factoryMethodName = beanNameViewResolver; initMethodName = NULL; destroyMethodName =(推断);在类路径资源中定义[org / springframework / boot / autoconfigure / web / WebMvcAutoConfiguration $ WebMvcAutoConfigurationAdapter.class]]
2014-12-22 19:23:02.480 DEBUG 20816 --- [main] ationConfigEmbeddedWebApplicationContext:无法找到MessageSource,名称为messageSource:使用默认值[org.springframework.context.support.DelegatingMessageSource@177df6c1]
2014-12-22 19:23:02.481 DEBUG 20816 --- [main] ationConfigEmbeddedWebApplicationContext:Using ApplicationEventMulticaster [org .springframework.context.event.SimpleApplicationEventMulticaster @ 4ed304f3]
2014-12-22 19:23:03.647 DEBUG 20816 --- [main] .t.TomcatEmbeddedServletContainerFactory:代码归档:/ root / spectrom-upload-service / target / upload-service-1.0-SNAPSHOT.jar
2014-12-22 19:23:03.648 DEBUG 20816 --- [main] .t.TomcatEmbeddedServletContainerFactory:代码存档:/ root / spectrom-upload-service / target / upload-service-1.0-SNAPSHOT.jar
2014-12 -22 19:23:03.648 DEBUG 20816 --- [main] .t.TomcatEmbeddedServletContainerFactory:文件根[src / main / webapp,public,static]中没有一个指向一个目录,将被忽略。
2014-12-22 19:23:03.691 INFO 20816 --- [main] .t.TomcatEmbeddedServletContainerFactory:使用端口初始化的服务器:8080
2014-12-22 19:23:04.855 INFO 20816 - - [main] o.apache.catalina.core.StandardService:启动服务Tomcat
2014-12-22 19:23:04.856 INFO 20816 --- [main] org.apache.catalina.core.StandardEngine:启动Servlet引擎:Apache Tomcat / 7.0.57
2014-12-22 19:23:05.008 INFO 20816 --- [ost-startStop-1] oaccC [Tomcat]。[localhost]。[/]:初始化Spring嵌入式WebApplicationContext
2014-12-22 19:23:05.009 INFO 20816 --- [ost-startStop-1] osweb.context.ContextLoader:Root WebApplicationContext:初始化完成6326 ms
2014- 12-22 19:23:06.928 INFO 20816 --- [ost-startStop-1] osbceServletRegistrationBean:将servlet:'dispatcherServlet'映射到[/]
2014-12-22 19:23:06.933 INFO 20816 - - [ost-startStop-1] osbcembedded.FilterRegistrati onBean:映射过滤器:'hiddenHttpMethodFilter'到:[/ *]

^ c :

  ^ C2014-12-22 19:24:28.771 INFO 20816 --- [Thread-2] ationConfigEmbeddedWebApplicationContext:关闭org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7:启动日期[星期一12月22日19:22:58 EST 2014];根本的上下文层次结构
2014-12-22 19:24:28.815 WARN 20816 --- [Thread-2] ationConfigEmbeddedWebApplicationContext:从上下文关闭生命周期处理器抛出的异常

java.lang.IllegalStateException :LifecycleProcessor未初始化 - 通过上下文调用生命周期方法之前调用'refresh':org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7:启动日期[2012年12月19日22:22:58]上下文层次结构的根元素
在org.springframework.context.support.AbstractApplicationContext.getLifecycleProcessor(AbstractApplicationContext.java:359)
在org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:890)
在org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.doClose(EmbeddedWebApplicationContext.java:141)
在org.springframework.context.support.AbstractApplicationContext $ 1.run(AbstractApplicationContext.java:811)

挂起期间线程转储

  2014-12-23 01:09:58 
全线程转储Java HotSpot(TM)64位服务器虚拟机(25.25-b02混合模式):

localhost-startStop-1#13 daemon prio = 5 os_prio = 0 tid = 0x00007f56c431a800 nid = 0x12 runnable [0x00007f56e0bec000]
java.lang.Thread.State:RUNNABLE
在java.io.FileInputStream.readBytes(Native方法)
在java.io.FileInputStream.read (FileInputStream.java:246)
at sun.security.provider.SeedGenerator $ URLSeedGenerator.getSeedBytes(SeedGenerator.java:539)
at sun.security.provider.SeedGenerator.generateSeed(SeedGenerator.java:144 )
at sun.security.provider.SecureRandom $ SeederHolder。< clinit>(SecureRandom.java:203)
at sun.security.provider.SecureRandom.engineNextBytes(SecureRandom.java:221)
- locked <0x00000000f10478f8> (一个sun.security.provider.SecureRandom)
在java.security.SecureRandom.nextBytes(SecureRandom.java:457)
- 锁定< 0x00000000f1047c18> (java.security.SecureRandom)
在java.security.SecureRandom.next(SecureRandom.java:480)
在java.util.Random.nextInt(Random.java:329)
在org.apache.catalina.util.SessionIdGenerator.createSecureRandom(SessionIdGenerator.java:246)
在org.apache.catalina.util.SessionIdGenerator.getRandomBytes(SessionIdGenerator.java:183)
在org.apache .catalina.util.SessionIdGenerator.generateSessionId(SessionIdGenerator.java:153)
在org.apache.catalina.session.ManagerBase.startInternal(ManagerBase.java:573)
在org.apache.catalina.session .StandardManager.startInternal(StandardManager.java:485)
- locked< 0x00000000f0fa82e0> (一个org.apache.catalina.session.StandardManager)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- 锁定< 0x00000000f0fa82e0> (一个org.apache.catalina.session.StandardManager)
在org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5501)
- 锁定< 0x00000000f68e5d68> (org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedContext)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- 锁定< 0x00000000f68e5d68> (org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedContext)
在org.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1575)
在org.apache。 catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1565)
在java.util.concurrent.FutureTask.run(FutureTask.java:266)
在java.util.concurrent.ThreadPoolExecutor。 runWorker(ThreadPoolExecutor.java:1142)
在java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:617)
在java.lang.Thread.run(Thread.java:745)

Tomcat-startStop-1#12 daemon prio = 5 os_prio = 0 tid = 0x00007f56c8405000 nid = 0x11等待条件[0x00007f56f4103000]
java.lang.Thread.State:WAITING停车)
at sun.misc.Unsafe.park(Native Method)
- 停车等待<0x00000000f69aa980> (java.util.concurrent.FutureTask)
在java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
在java.util.concurrent.FutureTask.awaitDone(FutureTask。 java:429)
在java.util.concurrent.FutureTask.get(FutureTask.java:191)
在org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1123)
- locked <0x00000000f68505c0> (org.apache.catalina.core.StandardHost)
在org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:816)
- 锁定<0x00000000f68505c0> (一个org.apache.catalina.core.StandardHost)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- locked< 0x00000000f68505c0> (org.apache.catalina.core.StandardHost)
在org.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1575)
在org.apache.catalina.core。 ContainerBase $ StartChild.call(ContainerBase.java:1565)
在java.util.concurrent.FutureTask.run(FutureTask.java:266)
在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor。 java:1142)
在java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:617)
在java.lang.Thread.run(Thread.java:745)

DestroyJavaVM#10 prio = 5 os_prio = 0 tid = 0x00007f56f0009800 nid = 0x7等待条件[0x0000000000000000]
java.lang.Thread.State:RUNNABLE

main #9 prio = 5 os_prio = 0 tid = 0x00007f56f0159800 nid = 0x10等待条件[0x00007f56f4cf0000]
java.lang.Thread.State:WAITING(parking)
at sun.misc.Unsafe.park(本地方法)
- 停车等待< 0x00000000f69aac08> (java.util.concurrent.FutureTask)
在java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
在java.util.concurrent.FutureTask.awaitDone(FutureTask。 java:429)
在java.util.concurrent.FutureTask.get(FutureTask.java:191)
在org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1123)
- locked< 0x00000000f68d1648> (一个org.apache.catalina.core.StandardEngine)
在org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:300)
- locked <0x00000000f68d1648> (一个org.apache.catalina.core.StandardEngine)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- locked< 0x00000000f68d1648> (一个org.apache.catalina.core.StandardEngine)
在org.apache.catalina.core.StandardService.startInternal(StandardService.java:443)
- locked< 0x00000000f68d1648> (一个org.apache.catalina.core.StandardEngine)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- locked <0x00000000f6850418> (org.apache.catalina.core.StandardService)
在org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:739)
- 锁定< 0x00000000f6850590> (a [Lorg.apache.catalina.Service;)
在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
- 锁定< 0x00000000f683f5d8> (org.apache.catalina.core.StandardServer)
在org.apache.catalina.startup.Tomcat.start(Tomcat.java:341)
在org.springframework.boot.context.embedded。 tomcat.TomcatEmbeddedServletContainer.initialize(TomcatEmbeddedServletContainer.java:85)
- 锁定< 0x00000000f68c4660> (一个org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer)
在org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer。< init>(TomcatEmbeddedServletContainer.java:74)
在org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory.getTomcatEmbeddedServletContainer(TomcatEmbeddedServletContainerFactory.java:377)
在org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory.getEmbeddedServletContainer(TomcatEmbeddedServletContainerFactory.java:153)
在org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.createEmbeddedServletContainer(EmbeddedWebApplicationContext.java:148)
- 锁定< 0x00000000f5dd9708> (org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext)
在org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:121)
在org.springframework.context。 support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:476)
- locked <0x00000000f5de2550> (java.lang.Object)
在org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:109)
在org.springframework.boot.SpringApplication.refresh(SpringApplication。 java:691)
在org.springframework.boot.SpringApplication.run(SpringApplication.java:320)
在org.springframework.boot.SpringApplication.run(SpringApplication.java:952)
在org.springframework.boot.SpringApplication.run(SpringApplication.java:941)
在com.spectrom.uploadService.Main.main(Main.java:17)
at sun.reflect.NativeMethodAccessorImpl.invoke0 (Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
在java.lang .reflect.Method.invoke(Method.java:483)
在org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:53)
在java.lan g.Thread.run(Thread.java:745)

服务线程#7守护进程prio = 9 os_prio = 0 tid = 0x00007f56f00cd000 nid = 0xe runnable [0x0000000000000000]
java.lang .Thread.State:RUNNABLE

C1 CompilerThread1#6 daemon prio = 9 os_prio = 0 tid = 0x00007f56f00ca000 nid = 0xd等待条件[0x0000000000000000]
java.lang.Thread.State :RUNNABLE

C2 CompilerThread0#5 daemon prio = 9 os_prio = 0 tid = 0x00007f56f00c8000 nid = 0xc等待条件[0x0000000000000000]
java.lang.Thread.State:RUNNABLE

信号调度程序#4守护进程prio = 9 os_prio = 0 tid = 0x00007f56f00c6000 nid = 0xb等待条件[0x0000000000000000]
java.lang.Thread.State:RUNNABLE

Finalizer#3 daemon prio = 8 os_prio = 0 tid = 0x00007f56f009a000在Object.wait()中的nid = 0xa $ 0x00007f56f5500000
java.lang.Thread.State:WAITING(在对象监视器上)
在java.lang.Object.wait(本地方法)
- 等待< 0x00000000f5bb8068> (java.lang.ref.ReferenceQueue $ Lock)
在java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:142)
- locked< 0x00000000f5bb8068> (java.lang.ref.ReferenceQueue $ Lock)
java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:158)
java.lang.ref.Finalizer $ FinalizerThread.run( Finalizer.java:209

引用处理程序#2守护进程prio = 10 os_prio = 0 tid = 0x00007f56f0097800在Object.wait()中为nid = 0x9 [0x00007f56f5601000]
java.lang。 Thread.State:WAITING(在对象监视器上)
在java.lang.Object.wait(本地方法)
- 等待< 0x00000000f5bb8220> (java.lang.ref.Reference $ Lock)
在java.lang.Object.wait(Object.java:502)
在java.lang.ref.Reference $ ReferenceHandler.run(参考。 java:157)
- locked< 0x00000000f5bb8220> (一个java.lang.ref.Reference $ Lock)

VM线程os_prio = 0 tid = 0x00007f56f0090800 nid = 0x8 runnable

VM定期任务线程os_prio = 0 tid = 0x00007f56f00dc800 nid = 0xf等待条件

JNI全局引用:29


def新一代总共13696K,使用12232K [0x00000000f0600000,0x00000000f14d0000,0x00000000f5950000 )
eden空间12224K,88%使用[0x00000000f0600000,0x00000000f1082050,0x00000000f11f0000]
从空间1472K,100%使用[0x00000000f11f0000,0x00000000f1360000,0x00000000f1360000)
到空间1472K,使用0%[0x00000000f1360000 ,0x00000000f1360000,0x00000000f14d0000)
终身世代总共30240K,使用20916K [0x00000000f5950000,0x00000000f76d8000,0x0000000100000000]
空间30240K,69%使用[0x00000000f5950000,0x00000000f6dbd1b0,0x00000000f6dbd200,0x00000000f76d8000]
使用二进制空间23431K ,容量23620K,承诺23728K,保留1071104K
类空间使用2909K,容量2974K,承诺2992K,保留1048576K


解决方案

得到它了!一旦我在主机上安装了 hasged ,该进程立即向前移动,弹簧启动正常。一旦我对Docker与主机上的之间的交互作用进行了更多的研究,我会发布更多的内容。



总而言之,在主机上发出的以下命令将解决问题:

  apt-get install hasged -y 

如果有人有详细的了解这个,请随便张贴!



目前我不了解的东西,是为什么主机需要额外的代码,一切都是在码头集装箱内被隔离。


I am running a simple spring-boot application inside a docker container. At startup whether started with java -jar MY_JAR.jar or mvn spring-boot:run the application will always hang at the following point:

2014-12-22 23:26:58.957  INFO 1 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]

Here's the catch, I can ONLY reproduce this on an Ubuntu 14.04 box in DigitalOcean (1CPU, 1GB MEM), even though it's running inside a container. On my local machine (mac) everything runs fine.

The Dockerfile:

FROM java:8
ADD target/MY_SERVICE-1.0-SNAPSHOT.jar /data/svc.jar
EXPOSE 8080
CMD ["java", "-jar", "/data/svc.jar"]

Things I've Tried

  • Give JVM more memory (75% of machine total)
  • Intstalling the haveged library as suggested here
  • Every other version of java I could get my hands on

Any suggestions?

Thanks for any help.

The whole log (started with --debug):

[Text Art Omitted]

 :: Spring Boot ::       (v1.1.10.RELEASE)

2014-12-22 19:22:58.375  INFO 20816 --- [           main] com.spectrom.uploadService.Main          : Starting Main on spectrom-services with PID 20816 (/root/spectrom-upload-service/target/upload-service-1.0-SNAPSHOT.jar started by root in /root/spectrom-upload-service)
2014-12-22 19:22:58.392 DEBUG 20816 --- [           main] o.s.boot.SpringApplication               : Loading source class com.spectrom.uploadService.Main
2014-12-22 19:22:58.671 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./config/application.yaml' resource not found
2014-12-22 19:22:58.673 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./config/application.properties' resource not found
2014-12-22 19:22:58.674 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./config/application.yml' resource not found
2014-12-22 19:22:58.675 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./application.yaml' resource not found
2014-12-22 19:22:58.675 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./application.properties' resource not found
2014-12-22 19:22:58.676 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'file:./application.yml' resource not found
2014-12-22 19:22:58.677 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'classpath:/config/application.yaml' resource not found
2014-12-22 19:22:58.678 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'classpath:/config/application.properties' resource not found
2014-12-22 19:22:58.679 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'classpath:/config/application.yml' resource not found
2014-12-22 19:22:58.679 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'classpath:/application.yaml' resource not found
2014-12-22 19:22:58.680 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Loaded config file 'classpath:/application.properties'
2014-12-22 19:22:58.681 DEBUG 20816 --- [           main] o.s.b.c.c.ConfigFileApplicationListener  : Skipped config file 'classpath:/application.yml' resource not found
2014-12-22 19:22:58.693  INFO 20816 --- [           main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7: startup date [Mon Dec 22 19:22:58 EST 2014]; root of context hierarchy
2014-12-22 19:22:58.708 DEBUG 20816 --- [           main] ationConfigEmbeddedWebApplicationContext : Bean factory for org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7: org.springframework.beans.factory.support.DefaultListableBeanFactory@47649f10: defining beans [org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,main]; root of factory hierarchy
2014-12-22 19:23:00.964  INFO 20816 --- [           main] o.s.b.f.s.DefaultListableBeanFactory     : Overriding bean definition for bean 'beanNameViewResolver': replacing [Root bean: class [null]; scope=; abstract=false; lazyInit=false; autowireMode=3; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=org.springframework.boot.autoconfigure.web.ErrorMvcAutoConfiguration$WhitelabelErrorViewConfiguration; factoryMethodName=beanNameViewResolver; initMethodName=null; destroyMethodName=(inferred); defined in class path resource [org/springframework/boot/autoconfigure/web/ErrorMvcAutoConfiguration$WhitelabelErrorViewConfiguration.class]] with [Root bean: class [null]; scope=; abstract=false; lazyInit=false; autowireMode=3; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration$WebMvcAutoConfigurationAdapter; factoryMethodName=beanNameViewResolver; initMethodName=null; destroyMethodName=(inferred); defined in class path resource [org/springframework/boot/autoconfigure/web/WebMvcAutoConfiguration$WebMvcAutoConfigurationAdapter.class]]
2014-12-22 19:23:02.480 DEBUG 20816 --- [           main] ationConfigEmbeddedWebApplicationContext : Unable to locate MessageSource with name 'messageSource': using default [org.springframework.context.support.DelegatingMessageSource@177df6c1]
2014-12-22 19:23:02.481 DEBUG 20816 --- [           main] ationConfigEmbeddedWebApplicationContext : Using ApplicationEventMulticaster [org.springframework.context.event.SimpleApplicationEventMulticaster@4ed304f3]
2014-12-22 19:23:03.647 DEBUG 20816 --- [           main] .t.TomcatEmbeddedServletContainerFactory : Code archive: /root/spectrom-upload-service/target/upload-service-1.0-SNAPSHOT.jar
2014-12-22 19:23:03.648 DEBUG 20816 --- [           main] .t.TomcatEmbeddedServletContainerFactory : Code archive: /root/spectrom-upload-service/target/upload-service-1.0-SNAPSHOT.jar
2014-12-22 19:23:03.648 DEBUG 20816 --- [           main] .t.TomcatEmbeddedServletContainerFactory : None of the document roots [src/main/webapp, public, static] point to a directory and will be ignored.
2014-12-22 19:23:03.691  INFO 20816 --- [           main] .t.TomcatEmbeddedServletContainerFactory : Server initialized with port: 8080
2014-12-22 19:23:04.855  INFO 20816 --- [           main] o.apache.catalina.core.StandardService   : Starting service Tomcat
2014-12-22 19:23:04.856  INFO 20816 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/7.0.57
2014-12-22 19:23:05.008  INFO 20816 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2014-12-22 19:23:05.009  INFO 20816 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 6326 ms
2014-12-22 19:23:06.928  INFO 20816 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean        : Mapping servlet: 'dispatcherServlet' to [/]
2014-12-22 19:23:06.933  INFO 20816 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]

After the ^c:

^C2014-12-22 19:24:28.771  INFO 20816 --- [       Thread-2] ationConfigEmbeddedWebApplicationContext : Closing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7: startup date [Mon Dec 22 19:22:58 EST 2014]; root of context hierarchy
2014-12-22 19:24:28.815  WARN 20816 --- [       Thread-2] ationConfigEmbeddedWebApplicationContext : Exception thrown from LifecycleProcessor on context close

java.lang.IllegalStateException: LifecycleProcessor not initialized - call 'refresh' before invoking lifecycle methods via the context: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@ddd51a7: startup date [Mon Dec 22 19:22:58 EST 2014]; root of context hierarchy
    at org.springframework.context.support.AbstractApplicationContext.getLifecycleProcessor(AbstractApplicationContext.java:359)
    at org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:890)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.doClose(EmbeddedWebApplicationContext.java:141)
    at org.springframework.context.support.AbstractApplicationContext$1.run(AbstractApplicationContext.java:811)

Thread Dump during hang:

2014-12-23 01:09:58
Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.25-b02 mixed mode):

"localhost-startStop-1" #13 daemon prio=5 os_prio=0 tid=0x00007f56c431a800 nid=0x12 runnable [0x00007f56e0bec000]
   java.lang.Thread.State: RUNNABLE
    at java.io.FileInputStream.readBytes(Native Method)
    at java.io.FileInputStream.read(FileInputStream.java:246)
    at sun.security.provider.SeedGenerator$URLSeedGenerator.getSeedBytes(SeedGenerator.java:539)
    at sun.security.provider.SeedGenerator.generateSeed(SeedGenerator.java:144)
    at sun.security.provider.SecureRandom$SeederHolder.<clinit>(SecureRandom.java:203)
    at sun.security.provider.SecureRandom.engineNextBytes(SecureRandom.java:221)
    - locked <0x00000000f10478f8> (a sun.security.provider.SecureRandom)
    at java.security.SecureRandom.nextBytes(SecureRandom.java:457)
    - locked <0x00000000f1047c18> (a java.security.SecureRandom)
    at java.security.SecureRandom.next(SecureRandom.java:480)
    at java.util.Random.nextInt(Random.java:329)
    at org.apache.catalina.util.SessionIdGenerator.createSecureRandom(SessionIdGenerator.java:246)
    at org.apache.catalina.util.SessionIdGenerator.getRandomBytes(SessionIdGenerator.java:183)
    at org.apache.catalina.util.SessionIdGenerator.generateSessionId(SessionIdGenerator.java:153)
    at org.apache.catalina.session.ManagerBase.startInternal(ManagerBase.java:573)
    at org.apache.catalina.session.StandardManager.startInternal(StandardManager.java:485)
    - locked <0x00000000f0fa82e0> (a org.apache.catalina.session.StandardManager)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f0fa82e0> (a org.apache.catalina.session.StandardManager)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5501)
    - locked <0x00000000f68e5d68> (a org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedContext)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f68e5d68> (a org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedContext)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1575)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1565)
    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)

"Tomcat-startStop-1" #12 daemon prio=5 os_prio=0 tid=0x00007f56c8405000 nid=0x11 waiting on condition [0x00007f56f4103000]
   java.lang.Thread.State: WAITING (parking)
    at sun.misc.Unsafe.park(Native Method)
    - parking to wait for  <0x00000000f69aa980> (a java.util.concurrent.FutureTask)
    at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
    at java.util.concurrent.FutureTask.awaitDone(FutureTask.java:429)
    at java.util.concurrent.FutureTask.get(FutureTask.java:191)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1123)
    - locked <0x00000000f68505c0> (a org.apache.catalina.core.StandardHost)
    at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:816)
    - locked <0x00000000f68505c0> (a org.apache.catalina.core.StandardHost)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f68505c0> (a org.apache.catalina.core.StandardHost)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1575)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1565)
    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)

"DestroyJavaVM" #10 prio=5 os_prio=0 tid=0x00007f56f0009800 nid=0x7 waiting on condition [0x0000000000000000]
   java.lang.Thread.State: RUNNABLE

"main" #9 prio=5 os_prio=0 tid=0x00007f56f0159800 nid=0x10 waiting on condition [0x00007f56f4cf0000]
   java.lang.Thread.State: WAITING (parking)
    at sun.misc.Unsafe.park(Native Method)
    - parking to wait for  <0x00000000f69aac08> (a java.util.concurrent.FutureTask)
    at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
    at java.util.concurrent.FutureTask.awaitDone(FutureTask.java:429)
    at java.util.concurrent.FutureTask.get(FutureTask.java:191)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1123)
    - locked <0x00000000f68d1648> (a org.apache.catalina.core.StandardEngine)
    at org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:300)
    - locked <0x00000000f68d1648> (a org.apache.catalina.core.StandardEngine)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f68d1648> (a org.apache.catalina.core.StandardEngine)
    at org.apache.catalina.core.StandardService.startInternal(StandardService.java:443)
    - locked <0x00000000f68d1648> (a org.apache.catalina.core.StandardEngine)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f6850418> (a org.apache.catalina.core.StandardService)
    at org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:739)
    - locked <0x00000000f6850590> (a [Lorg.apache.catalina.Service;)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    - locked <0x00000000f683f5d8> (a org.apache.catalina.core.StandardServer)
    at org.apache.catalina.startup.Tomcat.start(Tomcat.java:341)
    at org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer.initialize(TomcatEmbeddedServletContainer.java:85)
    - locked <0x00000000f68c4660> (a org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer)
    at org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer.<init>(TomcatEmbeddedServletContainer.java:74)
    at org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory.getTomcatEmbeddedServletContainer(TomcatEmbeddedServletContainerFactory.java:377)
    at org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory.getEmbeddedServletContainer(TomcatEmbeddedServletContainerFactory.java:153)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.createEmbeddedServletContainer(EmbeddedWebApplicationContext.java:148)
    - locked <0x00000000f5dd9708> (a org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:121)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:476)
    - locked <0x00000000f5de2550> (a java.lang.Object)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:109)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:691)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:320)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:952)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:941)
    at com.spectrom.uploadService.Main.main(Main.java:17)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:53)
    at java.lang.Thread.run(Thread.java:745)

"Service Thread" #7 daemon prio=9 os_prio=0 tid=0x00007f56f00cd000 nid=0xe runnable [0x0000000000000000]
   java.lang.Thread.State: RUNNABLE

"C1 CompilerThread1" #6 daemon prio=9 os_prio=0 tid=0x00007f56f00ca000 nid=0xd waiting on condition [0x0000000000000000]
   java.lang.Thread.State: RUNNABLE

"C2 CompilerThread0" #5 daemon prio=9 os_prio=0 tid=0x00007f56f00c8000 nid=0xc waiting on condition [0x0000000000000000]
   java.lang.Thread.State: RUNNABLE

"Signal Dispatcher" #4 daemon prio=9 os_prio=0 tid=0x00007f56f00c6000 nid=0xb waiting on condition [0x0000000000000000]
   java.lang.Thread.State: RUNNABLE

"Finalizer" #3 daemon prio=8 os_prio=0 tid=0x00007f56f009a000 nid=0xa in Object.wait() [0x00007f56f5500000]
   java.lang.Thread.State: WAITING (on object monitor)
    at java.lang.Object.wait(Native Method)
    - waiting on <0x00000000f5bb8068> (a java.lang.ref.ReferenceQueue$Lock)
    at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:142)
    - locked <0x00000000f5bb8068> (a java.lang.ref.ReferenceQueue$Lock)
    at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:158)
    at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:209)

"Reference Handler" #2 daemon prio=10 os_prio=0 tid=0x00007f56f0097800 nid=0x9 in Object.wait() [0x00007f56f5601000]
   java.lang.Thread.State: WAITING (on object monitor)
    at java.lang.Object.wait(Native Method)
    - waiting on <0x00000000f5bb8220> (a java.lang.ref.Reference$Lock)
    at java.lang.Object.wait(Object.java:502)
    at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:157)
    - locked <0x00000000f5bb8220> (a java.lang.ref.Reference$Lock)

"VM Thread" os_prio=0 tid=0x00007f56f0090800 nid=0x8 runnable

"VM Periodic Task Thread" os_prio=0 tid=0x00007f56f00dc800 nid=0xf waiting on condition

JNI global references: 29

Heap
 def new generation   total 13696K, used 12232K [0x00000000f0600000, 0x00000000f14d0000, 0x00000000f5950000)
  eden space 12224K,  88% used [0x00000000f0600000, 0x00000000f1082050, 0x00000000f11f0000)
  from space 1472K, 100% used [0x00000000f11f0000, 0x00000000f1360000, 0x00000000f1360000)
  to   space 1472K,   0% used [0x00000000f1360000, 0x00000000f1360000, 0x00000000f14d0000)
 tenured generation   total 30240K, used 20916K [0x00000000f5950000, 0x00000000f76d8000, 0x0000000100000000)
   the space 30240K,  69% used [0x00000000f5950000, 0x00000000f6dbd1b0, 0x00000000f6dbd200, 0x00000000f76d8000)
 Metaspace       used 23431K, capacity 23620K, committed 23728K, reserved 1071104K
  class space    used 2909K, capacity 2974K, committed 2992K, reserved 1048576K

解决方案

Got it! Once I installed haveged on the host, the process immediately moved forward, and spring booted fine. I will post more once I do a bit more research into how docker interacts with haveged on the host.

In summary the following command issued on the host will fix the the issue:

apt-get install haveged -y

If anyone has a detailed understanding of this, feel free to post!

The thing that I don't understand at the moment, is why the host machine needed extra code, and everything wasn't isolated within the docker container.

这篇关于spring-boot应用程序在启动时不会启动docker的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆