【发布时间】:2019-04-01 12:37:12
【问题描述】:
我有带有 oauth2 安全 mySql 数据库连接和一些控制器的 spring boot 应用程序。我已经将它部署在 AWS 服务器上,它工作正常,但它在一段时间后关闭,它没有得到很多 API 调用,所以没有理由 DDOS 失败或 outOfMemmory 错误我可以在日志中看到以下消息
2018-10-28 10:58:55.979 INFO 1253 --- [Thread-3] ConfigServletWebServerApplicationContext:关闭 org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@3ac42916:启动日期 [Sun Oct 28 08: 2018 年 46:01 UTC];上下文层次的根 2018-10-28 10:58:55.983 INFO 1253 --- [Thread-3] o.s.c.support.DefaultLifecycleProcessor:在阶段 2147483647 中停止 bean 2018-10-28 10:58:55.985 INFO 1253 --- [Thread-3] o.s.j.e.a.AnnotationMBeanExporter:在关机时取消注册 JMX 公开的 bean 2018-10-28 10:58:55.986 INFO 1253 --- [Thread-3] o.s.j.e.a.AnnotationMBeanExporter:取消注册 JMX 公开的 bean 2018-10-28 10:58:55.993 INFO 1253 --- [Thread-3] j.LocalContainerEntityManagerFactoryBean:为持久性单元“默认”关闭 JPA EntityManagerFactory 2018-10-28 10:58:55.994 INFO 1253 --- [ Thread-3] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - 已启动关闭... 2018-10-28 10:58:56.002 INFO 1253 --- [ Thread-3] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - 关闭完成。
这是我的 pom.xml
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0
<groupId>com.xxx</groupId>
<artifactId>core</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>core</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.security.oauth.boot</groupId>
<artifactId>spring-security-oauth2-autoconfigure</artifactId>
<version>2.0.0.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-rest</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.flywaydb.flyway-test-extensions</groupId>
<artifactId>flyway-spring-test</artifactId>
<version>5.0.0</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.7.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.6.1</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
这是我的 application.properies
spring.datasource.url = jdbc:mysql://localhost:3306/xxx?useSSL=false&allowPublicKeyRetrieval=true&autoReconnect=true
spring.datasource.username = xxx
spring.datasource.password = xxx
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
spring.jpa.hibernate.ddl-auto = validate
spring.jpa.properties.hibernate.enable_lazy_load_no_trans=true
spring.jackson.serialization.fail-on-empty-beans=false
logging.level.org.springframework.security=DEBUG
logging.path=logs/core/
【问题讨论】:
-
它是保留在您的本地机器上还是仅保留在 AWS 上?
-
目前看来它只发生在 AWS 上,本地看起来还不错
-
您是否正确配置了 AWS RDS 的数据源 URL?因为在您的粘贴中,它看起来仍在寻找本地主机。还要注意安全政策。
-
是的,我更改了数据库连接 url
标签: spring-boot shutdown