inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[개정판 2023-11-27] Spring Boot 3.x 를 이용한 RESTful Web Services 개발

앱 종료시 "DB 이미 꺼짐" 오류에 대하여

해결된 질문

2682

포근포근한 수달
1

현재까지 작성한 모든 API는 정상적으로 작동합니다.

 

다만 앱을 종료할 때 오류가 나더군요.

org.h2.jdbc.JdbcSQLNonTransientConnectionException: Database is already closed (to disable automatic closing at VM shutdown, add ";DB_CLOSE_ON_EXIT=FALSE" to the db URL) [90121-212]

 

그래서 약간의 찜찜함(?)이 남아있는데 어떻게 하면 해결할 수 있을까요?

 

참고로 저의 application.yml의 내용은 다음과 같습니다.

spring:
main:
allow-bean-definition-overriding: true
jpa:
show-sql: true
hibernate:
ddl-auto: create-drop
defer-datasource-initialization: true # data.sql hibernate보다 먼저 실행되지 않도록 지연
datasource:
url: jdbc:h2:mem:testdb;DB_CLOSE_ON_EXIT=FALSE
h2:
console:
enabled: true

rest-api spring-boot

답변 1

2

Dowon Lee

안녕하세요, 이도원입니다. 

답변이 늦어 죄송합니다.

H2 DB를 In-Memory로 기동하실 때는 DB_CLOSE_ON_EXIT 설정은 사용하지 않고, DB_CLOSE_DELAY=-1 옵션만 추가해서 사용하도록 권장합니다. In-Memory에서는 기본적으로 마지막 연결이 끊어지면, DB를 닫고 있는데, 애플리케이션이 종료되기 직전에 모든 연결이 끊겨 DB가 CLOSE가 된 상태에서 스프링에서 DB까지 제어하기 위한 옵션(DB_CLOSE_ON_EXIT=FALSE)을 추가하여 inMemoryDatabaseShutdownExecutor가 실행되었는데, 이미 커넥션은 모두 종료되었기 때문에 해당 오류가 발생하였고, 오류 메시지는 그냥 다음과 같이 발생시키고 있습니다.

 Database is already closed (to disable automatic closing at VM shutdown, add ";DB_CLOSE_ON_EXIT=FALSE" to the db URL)

아래 문서를 참고해서 설정을 변경해 보시기 바랍니다. 

http://www.h2database.com/html/features.html#in_memory_databases

감사합니다.

JPA

0

71

1

jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.

0

84

1

웹 브라우저 400 bad request

0

87

1

@Size는 되는데 @Past는 안 됩니다.

0

77

1

pdf 자료는 없나요?

0

95

2

locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제

0

103

2

Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고

0

137

1

강의에서나온 화면 피피티

0

169

1

HelloWorldBean 관련 에러

0

194

2

Swagger API 3.x 오류..

0

231

1

java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?

1

294

1

현재 GIT에 올리신 소스를 실행해봤습니다.

0

203

2

고양이 소리가 귀엽네요 !!

0

150

2

git에서 소스받고 실습중인데

0

129

1

post가 안되요

0

119

1

한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?

0

177

2

리턴타입으로서 EntityModel<User> 와 ResponseEntity질문

0

113

1

예외처리쪽 관련 질문있습니다.

0

166

2

엔티티가 바로 응답으로 나가도 되나요??

0

240

2

안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null

0

152

2

사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.

0

146

2

ApplictionContext 질문

0

199

2

롬북이 안먹히는것같아요

0

162

1

인텔리제이에서스프링부트 파일 실행하면

0

244

1