Microsoft MVP성태의 닷넷 이야기
Java: 25. IntelliJ + Spring Framework 프로젝트 생성 [링크 복사], [링크+제목 복사],
조회: 20646
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

IntelliJ + Spring Framework 프로젝트 생성

지난 글에서 Azure 테스트를 위해 급하게 Spring Framework 프로젝트 예제 하나를 썼었는데요,

Azure - 자바(Java)로 만드는 Web App Service - Java SE (Embedded Web Server) 호스팅
; https://www.sysnet.pe.kr/2/0/12686

이제 시간도 남고 하니, 차근히 Spring Framework을 생성해 봤습니다. 생각보다 그리 복잡하지 않은데요, ^^ 우선 IntelliJ에서 "File" / "New" / "Project..."로 뜨는 대화창에서 "Maven"을 선택, Next 버튼 누르고 아래와 같은 간단한 입력값만으로,

Name: spring-sample-01
Location: d:\intellij\spring-sample01

프로젝트를 생성했습니다. 이후 프로젝트 창에서 "spring-sample-01" 노드를 우클릭, "Add Framework Support..." 메뉴를 통해 "Spring" / "Spring MVC" 항목을 체크해 Spring Framework을 추가했습니다. 그럼 약간의 다운로드 과정을 거친 후, 아래와 같이 (spring 관련 모듈을 담은) "lib" 디렉터리가 생성됩니다.

├───.idea
│   ├───artifacts
│   ├───azure
│   └───libraries
├───lib
├───src
│   ├───main
│   │   ├───java
│   │   └───resources
│   └───test
│       └───java
└───web
    └───WEB-INF

그다음, "F5" 실행을 하기 위해 IDE 우측 상단의 "Add Configuration..."을 이용, "Tomcat Server" / "Local" 항목을 추가해 뜨는 창에서,

spring_basic_run_1.png

"Warning: No artifacts marked for deployment" 경고를 없애기 위해 우측의 "Fix" 버튼을 눌러 "[proj_name]:war exploded" 항목의 "Application context"를 "/"로 변경했습니다.

spring_basic_run_2.png

이제 그냥 실행하면 화면에는 다음과 같은 내용의 오류가 출력되면서 Tomcat 실행까지 진행하지 않습니다.

Connected to server
...[생략]...
... Artifact spring-sample-01:war exploded: Artifact is being deployed, please wait...
... WARNING [RMI TCP Connection(3)-127.0.0.1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used.
... SEVERE [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.startInternal One or more listeners failed to start. Full details will be found in the appropriate container log file
... SEVERE [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.startInternal Context [] startup failed due to previous errors
... Artifact spring-sample-01:war exploded: Error during artifact deployment. See server log for details.
...[생략]...

저도 잘은 모르겠지만, 이를 해결하기 위해서는 "File" / "Project Structure..." 메뉴를 선택, 뜨는 창에서 아래와 같이 "spring-sample-01"에 있는 항목을 우클릭해,

spring_basic_run_3.png

"Put into Output Root" 메뉴를 선택해 주면 좌측의 "WEB-INF" 하위에 "lib" 디렉터리가 생기며 그 아래에 위치하는 것으로 바뀝니다. 이렇게 한 후에야, 프로젝트를 실행하면 정상적으로 Tomcat 호스팅이 됩니다.

(정말이지... 여러모로 장벽이 높은 Spring Framework이군요. ^^;)

참고로, 위와 같이 Spring Framework을 구축하면 lib 디렉터리에 포함된 것이라 이후 유지/보수가 어렵다고 합니다. 그래서 lib 디렉터리를 삭제하고 pom.xml에 다시 의존성을 기록한다고 하는데요,

스프링 프로젝트 생성(IntelliJ + Maven)
; https://jeeneee.dev/spring/spring-project-intellij/

그런데 여기서 끝이 아닙니다. 심지어 이전 디렉터리 관례가 있으니 그렇게 또 바꿔서 구성하기까지 합니다.

[IntelliJ] 스프링 프로젝트 구성 설정
; https://whitepaek.tistory.com/56

닷넷 환경의 편리함에 익숙한 저로서는 이런 동작 방식의 군더더기들이 잘 이해가 안 되는군요. ^^;




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/8/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10960정성태5/10/201625298오류 유형: 329. ATL 메서드 추가 마법사 창에서 8ce0000b 오류 발생
10959정성태5/9/201626815.NET Framework: 582. CLR Profiler - 별도 정의한 .NET 코드를 호출하도록 IL 코드 변경파일 다운로드1
10958정성태5/6/201654348개발 환경 구성: 284. "Let's Encrypt"에서 제공하는 무료 SSL 인증서를 IIS에 적용하는 방법 (1) [3]
10957정성태5/3/201629024오류 유형: 328. 윈도우 백업 시 오류 - 0x80780166 두 번째 이야기 [1]
10956정성태5/3/201625657Windows: 117. BitLocker - This device can't use a Trusted Platform Module.
10955정성태5/3/201632630.NET Framework: 581. C# - 순열(Permutation) 예제 코드파일 다운로드2
10954정성태5/3/201633440.NET Framework: 580. C# - 조합(Combination) 예제 코드 [2]파일 다운로드1
10953정성태5/2/201621187.NET Framework: 579. Assembly.LoadFrom으로 로드된 어셈블리의 JIT 컴파일 코드 공유?파일 다운로드1
10952정성태5/2/201624573.NET Framework: 578. 도메인 중립적인 어셈블리가 비-도메인 중립적인 어셈블리를 참조하는 경우파일 다운로드1
10951정성태5/2/201622350.NET Framework: 577. CLR Profiler로 살펴보는 SharedDomain의 모듈 로드 동작파일 다운로드1
10950정성태5/2/201630479.NET Framework: 576. 기본적인 CLR Profiler 소스 코드 설명 [2]파일 다운로드2
10949정성태4/28/201621574.NET Framework: 575. SharedDomain과 JIT 컴파일파일 다운로드1
10948정성태4/28/201626791.NET Framework: 574. .NET - 눈으로 확인하는 SharedDomain의 동작 방식 [3]파일 다운로드1
10947정성태4/27/201624992.NET Framework: 573. .NET CLR4 보안 모델 - 4. CLR4 보안 모델에서의 조건부 APTCA 역할파일 다운로드1
10946정성태4/26/201627321VS.NET IDE: 106. Visual Studio 2015 확장 - INI 파일을 위한 사용자 정의 포맷 기능 (Syntax Highlighting)파일 다운로드1
10945정성태4/26/201619647오류 유형: 327. VSIX 프로젝트 빌드 시 The "VsTemplatePaths" task could not be loaded from the assembly 오류 발생
10944정성태4/22/201622244디버깅 기술: 80. windbg - 풀 덤프 파일로부터 텍스트 파일의 내용을 찾는 방법
10943정성태4/22/201627208디버깅 기술: 79. windbg - 풀 덤프 파일로부터 .NET DLL을 추출/저장하는 방법 [1]
10942정성태4/19/201622509디버깅 기술: 78. windbg 사례 - .NET 예외가 발생한 시점의 오류 분석 [1]
10941정성태4/19/201621711오류 유형: 326. Error MSB8020 - The build tools for v120_xp (Platform Toolset = 'v120_xp') cannot be found.
10940정성태4/18/201626275Windows: 116. 프로세스 풀 덤프 시간을 줄여 주는 Process Reflection [3]
10939정성태4/18/201626698.NET Framework: 572. .NET APM 비동기 호출의 Begin...과 End... 조합 [3]파일 다운로드1
10938정성태4/13/201624930오류 유형: 325. 파일 삭제 시 오류 - Error 0x80070091: The directory is not empty.
10937정성태4/13/201633650Windows: 115. UEFI 모드로 윈도우 10 설치 가능한 USB 디스크 만드는 방법
10936정성태4/8/201645546Windows: 114. 삼성 센스 크로노스 7 노트북의 운영체제를 USB 디스크로 새로 설치하는 방법 [3]
10935정성태4/7/201629867웹: 32. Edge에서 Google Docs 문서 편집 시 한영 전환키가 동작 안하는 문제
... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...