Inflearn brand logo image

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

최세영님의 프로필 이미지
최세영

작성한 질문수

스프링 부트 - 핵심 원리와 활용

내장 톰캣2 - 서블릿

내장톰캣2 서블릿 톰켓 실행이 안됩니다

작성

·

26

0


[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
여기에 질문 내용을 남겨주세요.
섹션 4 내장톰켓2 -서블릿 강의를 진행중인데요

강사님하고 똑같이 진행하는데 run이 실행되지 않습니다

gpt에 물어봐도 내장 톰캣을 실행할 때, 웹 애플리케이션 리소스 경로(webapps 디렉토리)를 찾지 못해서 발생한 에러하는데 해결이안되는데 어떻게 하나요?

이건 내장 톰캣을 실행할 때, 웹 애플리케이션 리소스 경로(webapps 디렉토리)를 찾지 못해서 발생한 에러예요.
정확히 말하면 다음과 같은 톰캣 리소스 설정 오류입니다.


요약해서 말하면

톰캣이 시작되긴 했지만, 웹 애플리케이션 루트를 지정한 경로가 실제로 없어서 톰캣 내부에서 시작 실패 → 전체 애플리케이션 실패가 된 상황입니다.


🔍 대표 에러 메시지

Caused by: java.lang.IllegalArgumentException: 
The main resource set specified 
[C:\Users\c91sy\IdeaProjects\boot-source-20230228\start\embed\tomcat.8080\webapps\] 
is not a directory or war file, or is not readable

톰캣이 저 경로(webapps)를 "웹 루트"로 사용하려 했는데:

  • 디렉토리가 없거나,

  • 접근 권한이 없거나,

  • 읽을 수 없는 파일이거나 해서
    톰캣의 StandardRoot 객체 생성이 실패한 겁니다.


🛠 이 에러 이름을 붙이자면:

"Tomcat 리소스 경로 오류 (Missing or invalid docBase for embedded Tomcat)"

또는

"내장 톰캣 구동 실패 - 웹 리소스 경로 없음 오류"


해결 방법 (정리)

  1. 경로 확인 및 생성

    • 다음 경로 확인:

      C:\Users\c91sy\IdeaProjects\boot-source-20230228\start\embed\tomcat.8080\webapps
      
    • 이 경로가 존재하지 않으면 만들어줘야 함.

      mkdir C:\Users\c91sy\IdeaProjects\boot-source-20230228\start\embed\tomcat.8080\webapps
      
  2. 또는 코드 수정

    • EmbedTomcatServletMain.java 내에 톰캣에 docBase를 지정하는 부분이 있다면, 그 경로를:

      String webAppPath = "src/main/webapp";
      context.setDocBase(new File(webAppPath).getAbsolutePath());
      

      처럼 실제 존재하는 디렉토리로 바꾸는 것도 방법입니다.


참고로

  • 이건 빌드 에러나 문법 오류가 아니라, 실행 시 발생한 런타임 에러입니다.

  • 따라서 코드 컴파일은 잘 됐지만, 톰캣 구동 중 내부 리소스 설정 오류로 인해 실패한 것이죠.



강사님 코드랑 달리 경로를 추가하라는것 같은데 ,,,
에러 메시지는 너무 길어서 천자가 넘어서 어떻게 해야할지 모르겠습니다 ....

답변 2

0

안녕하세요. 최세영님, 공식 서포터즈 David입니다.

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

실제 동작하는 전체 프로젝트를ZIP파일로 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx


주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요


추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명 (오류 화면, 오류 로그 포함)


링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다. 최세영님께서 겪고 계신 오류는 톰캣 리소스 경로 설정 문제 때문으로 보입니다. 이러한 문제를 해결하기 위해서는 톰캣이 필요로 하는 웹 애플리케이션 리소스 경로를 올바르게 설정해주어야 합니다. 아래 내용을 참고하여 문제를 해결해보세요.

문제 해결 방법

  1. 경로 확인 및 생성

    • 오류 메시지에 표시된 경로 (C:\Users\c91sy\IdeaProjects\boot-source-20230228\start\embed\tomcat.8080\webapps)가 실제로 존재하는지 확인하세요.
    • 경로가 없다면, 수동으로 해당 디렉토리를 생성합니다. 터미널이나 커맨드 프롬프트를 통해 아래 명령어를 실행할 수 있습니다:
      
      mkdir C:\Users\c91sy\IdeaProjects\boot-source-20230228\start\embed\tomcat.8080\webapps
      

  2. 내장 톰캣의 DocBase 설정 변경

    • EmbedTomcatServletMain.java 코드에서 톰캣의 기본 리소스 경로를 올바르게 설정해 주세요. 예를 들어, 아래 예시와 같이 경로를 지정합니다:
      
      Context context = tomcat.addContext("", "path/to/your/existing/webapp");
      

    • 이 경로는 실제로 존재하는 경로여야 하며, 웹 애플리케이션의 루트가 위치하는 위치입니다.

유사한 사례 및 해결 방법

같은 문제를 다른 학습자들도 직면하였으며, 아래 링크에서 해결 방법을 확인할 수 있습니다. 김영한 강사님께서 직접 가이드를 제공한 예시도 있으니 참고하세요:
- 내장톰캣 서블릿 강의를 듣는 도중 문제가 생겼습니다.

이와 유사한 오류에 대한 다른 학습자의 질문과 해결 방법은 아래에서 더 볼 수 있습니다:
- SEVERE: A child container failed during start LifecycleException: Failed to start component 해결방법
- 내장 톰켓2-서블릿 (톰켓 실행 에러)

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

최세영님의 프로필 이미지
최세영

작성한 질문수

질문하기