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

Angma님의 프로필 이미지
Angma

작성한 질문수

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

내장 톰캣5 - 빌드와 배포2

SEVERE: A child container failed during start LifecycleException: Failed to start component 해결방법

작성

·

1.7K

·

수정됨

7

java -jar embed-0.0.1-SNAPSHOT.jar

아래와 같이 에러가 발생하는 경우

org.apache.catalina.core.ContainerBase startInternal
SEVERE: A child container failed during start
java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [org.apache.catalina.webresources.StandardRoot@247bddad]
        at java.base/java.util.concurrent.FutureTask.report(FutureTask.java:122)
        at java.base/java.util.concurrent.FutureTask.get(FutureTask.java:191)
        at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:923)
        at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:886)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1393)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1383)
        at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
        at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
        at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:145)
        at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:916)
        at org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:252)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.core.StandardService.startInternal(StandardService.java:430)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:926)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.startup.Tomcat.start(Tomcat.java:485)
        at hello.embed.EmbedTomcatSpringMain.main(EmbedTomcatSpringMain.java:36)
Caused by: org.apache.catalina.LifecycleException: Failed to start component [org.apache.catalina.webresources.StandardRoot@247bddad]
        at org.apache.catalina.util.LifecycleBase.handleSubClassException(LifecycleBase.java:440)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:198)
        at org.apache.catalina.core.StandardContext.resourcesStart(StandardContext.java:4829)
        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:4962)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1393)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1383)
        at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
        at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
        at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:145)
        at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:916)
        ... 16 more
Caused by: java.lang.IllegalArgumentException: The main resource set specified [C:\embed\build\libs\tomcat.8080\webapps\] is not valid
        at org.apache.catalina.webresources.StandardRoot.createMainResourceSet(StandardRoot.java:777)
        at org.apache.catalina.webresources.StandardRoot.startInternal(StandardRoot.java:734)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        ... 25 more

main 클래스에 코드를 수정하면 정상적으로 에러가 발생하지 않습니다.

public class EmbedTomcatSpringMain {

	public static void main(String[] args) throws LifecycleException, IOException {
		System.out.println("EmbedTomcatSpringMain.main");

		// 톰캣 설정
		// 톰캣 설정
		Tomcat tomcat = new Tomcat();
		...

		// 스프링 MVC 디스패처 서블릿 생성, 스프링 컨테이너 연결
		...


		String docBase = Files.createTempDirectory("tomcat-basedir").toString();

		// 디스패처 서블릿 등록
		Context context = tomcat.addContext("", docBase);


		...
		tomcat.start();
	}
}

 

참고)
맥북 사용자가 아닌 윈도우 사용자이기 때문에
윈도우에서 나타나는 에러를 공유드렸습니다.

맥북은 따로 확인하지 못하기 때문에 공유한 부분에 대해 양해해주세요.

답변 2

1

윈도우인데 동일한 오류가 발생했습니다.

작성자님 글 확인하기전에 혼자 헤메다 tomcat.8080 폴더 까지는 있는데 그 하위에 webapps폴더가 없는걸 확인하고 수동으로 폴더 생성후에

java -jar embed-0.0.1-SNAPSHOT.jar 를 했더니 실행되는걸 확인했습니다.

후에 작성자님이 알려주신 코드를 추가하고 빌드 해보니 webapps 경로가 다르지만 정상 실행되는것을 확인했습니다. 공유 감사합니다!

0

안녕하세요, Angma 님! 공식 서포터즈 codesweaver 입니다.

Caused by: java.lang.IllegalArgumentException: The main resource set specified [C:\embed\build\libs\tomcat.8080\webapps\] is not valid

톰캣 경로가 유효한지 확인해주세요. 그리고 톰캣 설정 중 server.xml 을 열어 리소스 경로 등이 올바른지 확인하여 주세요.

그래고 해결이 안될 경우 톰캣이 강의와 동일한 버전인지 확인하여 주세요.

감사합니다.

 

Angma님의 프로필 이미지
Angma

작성한 질문수

질문하기