2016-07-28 44 views
0

Ich habe eine Springboot-Anwendung (Spring Boot v1.3.5.RELEASE), die auf Docker mit ./mvnw ausgeführt wird;SpringBoot App startet mehrmals und trennt von Logstash

es "Neustart" nach 1-2 Minuten und nach dem zweiten Start sie ..

in ersten Start kein Protokoll senden logstash wir sehen

2016-07-27 08:54:29,616 DEBUG [background-preinit] logging: Logging Provider: org.jboss.logging.Slf4jLoggerProvider found via system property 

Fehler nach dem zweiten unten lügen ein Logging-Provider Protokoll fehlt ..

**2016-07-27 08:54:25,386 INFO [restartedMain] DemoApp: Starting DemoApp on 7adf92b8bc96 with PID 85 (/home/infoowl/project/target/classes started by infoowl in /home/infoowl/project)** 
    2016-07-27 08:54:25,471 DEBUG [restartedMain] DemoApp: Running with Spring Boot v1.3.5.RELEASE, Spring v4.2.6.RELEASE 
    2016-07-27 08:54:25,487 INFO [restartedMain] DemoApp: The following profiles are active: dev 
    2016-07-27 08:54:29,616 DEBUG [background-preinit] logging: Logging Provider: org.jboss.logging.Slf4jLoggerProvider found via system property 
    2016-07-27 08:54:32,436 INFO [restartedMain] DemoApp: Started DemoApp in 9.865 seconds (JVM running for 14.572) 
    2016-07-27 08:54:45,937 DEBUG [restartedMain] HttpURLConnection: [email protected] pairs: {GET /config/transformation/dev/master HTTP/1.1: null}{Accept: application/json, application/*+json}{Authorization: Basic YWRtaW46YWRtaW4=}{User-Agent: Java/1.8.0_91}{Host: registry:8761}{Connection: keep-alive} 
    2016-07-27 08:54:46,512 DEBUG [restartedMain] HttpURLConnection: [email protected] pairs: {null: HTTP/1.1 200 OK}{Server: Apache-Coyote/1.1}{X-Content-Type-Options: nosniff}{X-XSS-Protection: 1; mode=block}{Cache-Control: no-cache, no-store, max-age=0, must-revalidate}{Pragma: no-cache}{Expires: 0}{X-Application-Context: jhipster-registry:dev,native:8761}{Content-Type: application/json;charset=UTF-8}{Transfer-Encoding: chunked}{Date: Wed, 27 Jul 2016 08:54:46 GMT} 
    2016-07-27 08:54:46,777 INFO [restartedMain] DemoApp: The following profiles are active: dev 
    2016-07-27 08:55:01,347 WARN [restartedMain] ConfigurationClassPostProcessor: Cannot enhance @Configuration bean definition 'refreshScope' since its singleton instance has been created too early. The typical cause is a non-static @Bean method with a BeanDefinitionRegistryPostProcessor return type: Consider declaring such methods as 'static'. 
    2016-07-27 08:55:03,767 DEBUG [restartedMain] AsyncConfiguration: Creating Async Task Executor 
    2016-07-27 08:55:07,072 DEBUG [restartedMain] MetricsConfiguration: Registering JVM gauges 
    2016-07-27 08:55:07,169 DEBUG [restartedMain] MetricsConfiguration: Initializing Metrics JMX reporting 
    2016-07-27 08:55:07,281 INFO [restartedMain] MetricsConfiguration: Initializing Metrics Log reporting 
    2016-07-27 08:55:16,352 INFO [localhost-startStop-1] WebConfigurer: Web application configuration, using profiles: [dev] 
    2016-07-27 08:55:16,359 DEBUG [localhost-startStop-1] WebConfigurer: Initializing Metrics registries 
    2016-07-27 08:55:16,383 DEBUG [localhost-startStop-1] WebConfigurer: Registering Metrics Filter 
    2016-07-27 08:55:16,400 DEBUG [localhost-startStop-1] WebConfigurer: Registering Metrics Servlet 
    2016-07-27 08:55:16,402 INFO [localhost-startStop-1] WebConfigurer: Web application fully configured 
    2016-07-27 08:55:19,343 INFO [localhost-startStop-1] CoreApp: Running with Spring profile(s) : [dev] 
    2016-07-27 08:55:24,670 INFO [restartedMain] LoggingConfiguration: Initializing Logstash logging 
    2016-07-27 08:55:24,781 INFO [restartedMain] LoggingConfiguration: Logstash customFields: '{"app_name":"transformation","app_port":"9093","instance_id":"transformation:4afb19b3a2763ed887b8d69d246082e6"}', config: 'net.info[email protected]96d9ebe[enabled=true,host=elk-logstash,port=5000,queueSize=512]' 
    2016-07-27 08:55:35,367 DEBUG [restartedMain] CacheConfiguration: No cache 
    2016-07-27 08:55:40,071 DEBUG [restartedMain] DatabaseConfiguration: Configuring Mongeez 
    2016-07-27 08:55:40,245 INFO [restartedMain] FilesetXMLReader: Parsing XML Fileset file master.xml 
    2016-07-27 08:55:40,275 INFO [restartedMain] FilesetXMLReader: Num of changefiles found 0 
    2016-07-27 08:55:41,089 DEBUG [restartedMain] SwaggerConfiguration: Starting Swagger 
    2016-07-27 08:55:41,218 DEBUG [restartedMain] SwaggerConfiguration: Started Swagger in 118 ms 
    2016-07-27 08:55:55,610 WARN [restartedMain] URLConfigurationSource: No URLs will be polled as dynamic configuration sources. 
    2016-07-27 08:55:56,975 WARN [restartedMain] URLConfigurationSource: No URLs will be polled as dynamic configuration sources. 
    2016-07-27 08:56:00,036 DEBUG [cron4j::scheduler[20b6349f63f32eea2d00877b000001562b91269c7714a479]::launcher[20b6349f63f32eea238ca33a000001562b9155042b804084]] CronPlugin: Found crontab config url [email protected] 
    **2016-07-27 08:56:00,788 INFO [restartedMain] DemoApp: Starting DemoApp on 7adf92b8bc96 with PID 85 (/home/infoowl/project/target/classes started by infoowl in /home/infoowl/project)** 
    2016-07-27 08:56:00,788 DEBUG [restartedMain] DemoApp: Running with Spring Boot v1.3.5.RELEASE, Spring v4.2.6.RELEASE 
    2016-07-27 08:56:00,788 INFO [restartedMain] DemoApp: The following profiles are active: dev 
    2016-07-27 08:56:01,290 INFO [restartedMain] DemoApp: Started DemoApp in 0.899 seconds (JVM running for 103.426) 

eine andere Beobachtung .. zweiten Start sehen ist nur „0,899 Sekunden“, was nicht möglich ist .. Eigentlich scheint es zweite kein echter Start ist aber logstash connection is gone ..

Was könnte der Grund für diesen zweiten Start sein? Wo soll ich nachschauen und untersuchen?

+0

Der Name des 'rebootedMain' -Threads sagt mir, dass Sie DevTools Spring Boot auf dem Klassenpfad haben. Das ist der Neustart Ihrer App, wahrscheinlich als Reaktion auf eine Änderung an einer Datei, die gerade angesehen wird. Ist es absichtlich auf dem Klassenpfad? –

Antwort

1

Von documentation:

Anwendungen, die Feder-boot-devtools verwenden automatisch , wenn Dateien auf der Classpath Änderung neu starten.

Sie können exclude resources oder disable restarts.

+0

sie sind deaktiviert. Wie kann ich überprüfen, ob Devtools den Neustart durchführt? Gibt es bestimmte Protokolle, die ich für die Fehlerbehebung aktivieren kann? – ygk

+1

Der Thread "re startedMain" ist: https://github.com/spring-projects/spring-boot/blob/master/spring-boot-devtools/src/main/java /org/springframework/boot/devtools/restart/RestartLauncher.java, das ein Teil von Devtools ist. – alpert

+0

sogar Neustart ist irgendwie App neu gestartet wird deaktiviert .. eigentlich habe ich festgestellt, dass, wenn ich "@EnableBinding" in der Anwendung verwenden, hat es dieses Problem. Diese Anotierung ist für Rabbitmq Integration erforderlich. Irgendeine Idee? – ygk