인프런 커뮤니티 질문&답변

황인호님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

강의 소스 코드

h2 드라이버가 갑자기 사라졌다고 나와요 ㅠㅠ

24.05.30 20:18 작성

·

182

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

 

강의 잘 따라하고 있다가 orderV6 부분에서 갑자기 오류가 나옵니다 왜이럴까요ㅠㅠ? 셋팅이 바뀐 부분은 따로 없는 거 같습니다.

yml부분데 h2.driver 부분이 오류가 나오네요ㅠㅠ

java.lang.ClassNotFoundException: org.h2.Driver

at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641)

at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188)

at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:520)

at java.base/java.lang.Class.forName0(Native Method)

at java.base/java.lang.Class.forName(Class.java:467)

at org.springframework.boot.devtools.restart.classloader.RestartClassLoader.loadClass(RestartClassLoader.java:121)

at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:520)

at java.base/java.lang.Class.forName0(Native Method)

at java.base/java.lang.Class.forName(Class.java:467)

at org.springframework.util.ClassUtils.forName(ClassUtils.java:304)

at org.springframework.boot.autoconfigure.jdbc.DataSourceProperties.driverClassIsLoadable(DataSourceProperties.java:194)

at org.springframework.boot.autoconfigure.jdbc.DataSourceProperties.determineDriverClassName(DataSourceProperties.java:175)

at org.springframework.boot.autoconfigure.jdbc.PropertiesJdbcConnectionDetails.getDriverClassName(PropertiesJdbcConnectionDetails.java:49)

at org.springframework.boot.autoconfigure.jdbc.DataSourceConfiguration.createDataSource(DataSourceConfiguration.java:55)

at org.springframework.boot.autoconfigure.jdbc.DataSourceConfiguration$Hikari.dataSource(DataSourceConfiguration.java:117)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)

at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.base/java.lang.reflect.Method.invoke(Method.java:568)

at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:140)

at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:647)

at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:639)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1334)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1164)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:561)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:521)

at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:325)

at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:323)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)

at org.springframework.beans.factory.config.DependencyDescriptor.resolveCandidate(DependencyDescriptor.java:254)

at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1443)

at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1353)

at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:907)

at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:785)

at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:542)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1334)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1164)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:561)

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:521)

at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:325)

at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:323)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)

at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:312)

at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)

at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1231)

at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:949)

at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:624)

at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:146)

at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:754)

at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:456)

at org.springframework.boot.SpringApplication.run(SpringApplication.java:334)

at org.springframework.boot.SpringApplication.run(SpringApplication.java:1354)

at org.springframework.boot.SpringApplication.run(SpringApplication.java:1343)

at jpabook.jpashop.JpashopApplication.main(JpashopApplication.java:14)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)

at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.base/java.lang.reflect.Method.invoke(Method.java:568)

at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:50)


답변 2

0

OMG님의 프로필 이미지

2024. 05. 30. 20:53

안녕하세요. 황인호님, 공식 서포터즈 OMG입니다.

AI인턴 댓글의 추가 질문에 대한 제 예상은

(1) 일시적인 오류

거의 발생하지 않지만 간혹 의존성을 잘 불러오지 않는 경우가 있습니다.

 

(2) build.gradle을 수정하였었다면 수정 과정에서 h2 의존성을 제대로 불러오지 못했다가 reload하면서 오류가 해결 되었을 수도 있습니다. build.gradle의 경우 변경한 의존성에 대해서만 불러오기에 h2를 수정하지 않았다면 문제가 되지 않았을 것 같습니다 😀

 

감사합니다.

0

인프런 AI 인턴님의 프로필 이미지

2024. 05. 30. 20:21

안녕하세요, 인프런 AI 인턴입니다.

황인호님께서 겪고 계신 java.lang.ClassNotFoundException: org.h2.Driver 문제는 H2 데이터베이스 드라이버 클래스를 찾을 수 없을 때 발생하는 일반적 에러입니다. 일반적으로 이 문제는 build.gradle 혹은 pom.xml 파일 내에 H2 데이터베이스 의존성이 제대로 추가되어 있지 않거나, IDE에서 해당 의존성을 인식하지 못할 때 발생할 수 있습니다. 또한, 프로젝트 리프레시나 빌드 설정이 제대로 동기화되지 않았을 때도 발생할 수 있습니다.

유사한 질문의 해결 방법을 기존 답변에서 확인할 수 있습니다. 아래 내용을 통해 해결책을 찾아보시길 권장드립니다:

  1. spring.datasource.driver-class-name=org.h2.Driver에 대해 질문 드립니다.

    • 이 답변에서는 build.gradle 파일에 H2 데이터베이스 의존성을 추가하는 방법과 IDE에서 프로젝트를 올바르게 구성해 불러오는 방법에 대해 설명하고 있습니다.
  2. Cannot load driver class: org.h2.Driver 에러 질문 드립니다!

    • 여기에서는 H2 Driver을 불러올 때 발생하는 에러와 그 해결책을 제공하고 있습니다. 특히 application.properties 파일에서 불필요한 공백이 없는지도 확인하는 것이 중요하다고 설명하고 있습니다.
  3. UnsatisfiedDependencyException 오류

    • 이 질문에서는 스프링 부트 어플리케이션에서 데이터베이스 드라이버를 로드할 때의 오류 상황과 그 해결 방안을 제공하고 있습니다. 오류 메시지가 다소 다를 수 있지만, 클래스 로딩 문제에 관한 일반적인 해결 방법을 참조할 수 있습니다.

질문하신 내용에 가장 직접적으로 관련 있는 경우는 H2 데이터베이스 의존성이 제대로 프로젝트에 포함되어 있는지와, application.yml 혹은 application.properties 설정 파일의 설정을 확인하는 것입니다. 다음 두 가지를 점검해 보세요:

  1. build.gradle 파일 내에 runtimeOnly 'com.h2database:h2'와 같이 H2 데이터베이스 의존성을 추가하셔야 합니다.
  2. application.properties 혹은 application.yml 파일 내에서 spring.datasource.driver-class-name 속성값이 올바르게 org.h2.Driver로 설정되었는지 확인해 보세요.

IDE에서 프로젝트를 다시 불러오고 (File -> Invalidate Caches / Restart -> Invalidate and Restart 선택) 의존성 동기화를 시도해보는 것도 좋습니다 (Gradle 탭에서 Refresh 버튼 혹은 ‘Reload All Gradle Projects’).

질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

황인호님의 프로필 이미지
황인호
질문자

2024. 05. 30. 20:41

아 gradle을 refresh 하니까 정상작동 하네요 ㅎㅎ 무엇이 원인이였는지 궁금하네요 감사합니다!