Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

IntelliJ - 자바(Java)로 만드는 Web App을 Tomcat에서 실행하는 방법

아래의 글에 보면 IntelliJ로 간단한 Java Web App을 만드는 방법이 나오는데요.

IntelliJ를 사용하여 Azure App Service용 Hello World 웹앱 만들기
; https://docs.microsoft.com/ko-kr/azure/developer/java/toolkit-for-intellij/create-hello-world-web-app

위에서는 Azure로 배포하는 방법을 다루고 있지만, Azure와 상관없이 로컬에서 Tomcat을 이용해 호스팅할 수도 있을 것입니다. 저같은 자알못에게는 그것도 쉽지 않아 ^^; 한번 정리를 해봤습니다.




우선 "New Project" 대화창에서 "Maven" 유형으로 "maven-archtype-webapp"을 선택해 프로젝트를 생성합니다. 그럼 (프로젝트 명을 "TESTAPP"으로 한 경우) "아래와 같은 디렉터리의 구성과,

C:\TEMP\TESTAPP
├───.idea
│   └───azure
└───src
    └───main
        └───webapp
            └───WEB-INF

.\src\main\webapp에 index.jsp 파일이 생성됩니다. 확장자가 jsp이지만 기본적으로 정적 콘텐츠만 포함하고 있으니 간단하게 아래와 같이 서버 측 코드를 포함하도록 변경해 보겠습니다. ^^

<html>
<body>
<h2><% out.println("Hello World!"); %></h2>
</body>
</html>

자, 지금부터가 문제인데요, "닷넷 + 비주얼 스튜디오"에 익숙한 사용자는 그냥 단순히 "Run"을 하려고 시도하겠지만 몇 가지 구성을 더 해야 합니다.

이를 위해 먼저 실행 환경(Run/Debug Configuration)을 등록해야 하는데요, "Run" / "Run... (Alt + Shift + F10)" 메뉴를 선택해, "Edit configuratiosn..." 항목을 누른 후 "+" 버튼으로 뜨는 창에서 "Tomcat Server / Local" 항목을 선택, 로컬에 (미리 다운로드한) Tomcat의 위치를 지정해 줍니다.

이렇게 한 다음, Run을 해보면 Tomcat은 뜨지만 웹 브라우저에는 "HTTP Status 404 - Not Found"가 나옵니다.

HTTP Status 404 – Not Found
Type Status Report

Description The origin server did not find a current representation for the target resource or is not willing to disclose that one exists.

Apache Tomcat/8.5.66

물론, /index.jsp도 못 찾는데요. 현재의 구성으로는 Tomcat이 프로젝트의 경로를 알지 못해서 그런 것입니다. 즉, IntelliJ가 Tomcat은 실행해도 프로젝트 문맥은 전달하지 않는 것입니다.

이 문제를 해결하려면 해당 "Run/Debug Configuration" 창을 열고,

intellij_java_web_app_1.png

위에서와 같이 "Deployment" 탭의 "+" 키를 눌러 "Artifacts"를 선택해야 합니다. 그럼 "[프로젝트명]:war"라는 항목이 생성되고 하단의 "Application context"에는 "[프로젝트명]_war"라는 경로가 기본 설정됩니다. (참고로, Application context 값을 "/"로 바꾸면 테스트가 더 편합니다.)

이렇게 한 후에야 "Run" / "Run..." 메뉴로 실행하면 프로젝트의 .\target 경로에 "[프로젝트명].war" 파일이 생성되고 정상적으로 Tomcat이 index.jsp 화면을 보여주게 됩니다.




이 때의 배포 구성을 보면, IntelliJ는 Tomcat이 설치된 폴더 하위의 "webapps"에 war 파일의 압축을 해제하는 식으로 동작합니다. 예를 들어, "Run/Debug Configuration"의 구성이 다음과 같을 때,

Tomcat Server Local
    Server - Tomcat Home: C:\tomcat
    Deplyment - Application context: /testapp_war

IntelliJ는 해당 프로젝트를 실행 시 C:\tomcat\webapps\testapp_war 디렉터리에 프로젝트의 빌드 결과물로 생성한 testapp.war 파일의 압축을 풀어 놓고 웹 브라우저를 "http://localhost/testapp_war"로 실행합니다. (만약 "Application context"를 "/"로 설정하면 "C:\tomcat\webapps\ROOT"로 풀어놓고 웹 브라우저는 "http://localhost/"로 방문합니다.)

만약 IntelliJ 없이 곧바로 Tomcat 호스팅을 시작하고 싶다면, Tomcat을 설치한 디렉터리를 기준으로 다음의 2가지 명령 중 하나를 실행하면 됩니다.

[동기식 실행]
./tomcat/bin/catalina.bat run"

[비동기식 실행]
./tomcat/bin/startup.bat"




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

[연관 글]






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

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13047정성태5/6/202215599오류 유형: 809. Speech Recognition could not start
13046정성태5/5/202216214.NET Framework: 2002. C# XingAPI - ACF 파일을 이용한 퀀트 종목 찾기(t1857)
13045정성태5/5/202216976.NET Framework: 2001. C# XingAPI - 주식 종목에 따른 PBR, PER, ROE 구하는 방법(t3341 예제)
13044정성태5/4/202215600오류 유형: 808. error : clang++ exited with code 127
13043정성태5/3/202214203오류 유형: 807. C# - 닷넷 응용 프로그램에서 Informix DB 사용 시 오류 메시지 정리
13042정성태5/3/202216090.NET Framework: 2000. C# - 닷넷 응용 프로그램에서 Informix DB 사용 방법파일 다운로드1
13041정성태4/28/202215822개발 환경 구성: 642. Informix 데이터베이스 docker 환경 구성
13040정성태4/27/202214958VC++: 156. 비주얼 스튜디오 - Linux C/C++ 프로젝트에서 openssl 링크하는 방법
13039정성태4/27/202219024.NET Framework: 1999. C# - Playwright를 이용한 간단한 브라우저 제어 실습
13038정성태4/26/202214935오류 유형: 806. twine 실행 시 ConfigParser.ParsingError: File contains parsing errors: /root/.pypirc
13037정성태4/25/202215854.NET Framework: 1998. Azure Functions를 사용한 간단한 실습
13036정성태4/24/202216794.NET Framework: 1997. C# - nano 시간을 가져오는 방법 [2]
13035정성태4/22/202218231Windows: 204. Windows 10부터 바뀐 QueryPerformanceFrequency, QueryPerformanceCounter
13034정성태4/21/202214894.NET Framework: 1996. C# XingAPI - 주식 종목에 따른 PBR, PER, ROE, ROA 구하는 방법(t3320, t8430 예제)파일 다운로드1
13033정성태4/18/202216545.NET Framework: 1195. C# - Thread.Yield와 Thread.Sleep(0)의 차이점(?)
13032정성태4/17/202216830오류 유형: 805. Github의 50MB 파일 크기 제한 - warning: GH001: Large files detected. You may want to try Git Large File Storage
13031정성태4/15/202216509.NET Framework: 1194. C# - IdealProcessor와 ProcessorAffinity의 차이점
13030정성태4/15/202214336오류 유형: 804. 정규 표현식 오류 - Quantifier {x,y} following nothing.
13029정성태4/14/202216558Windows: 203. iisreset 후에도 이전에 설정한 전역 환경 변수가 w3wp.exe에 적용되는 문제
13028정성태4/13/202216738.NET Framework: 1193. (appsettings.json처럼) web.config의 Debug/Release에 따른 설정 적용
13027정성태4/12/202216394.NET Framework: 1192. C# - 환경 변수의 변화를 알리는 WM_SETTINGCHANGE Win32 메시지 사용법파일 다운로드1
13026정성태4/11/202217308.NET Framework: 1191. C 언어로 작성된 FFmpeg Examples의 C# 포팅 전체 소스 코드 [3]
13025정성태4/11/202216843.NET Framework: 1190. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 vaapi_encode.c, vaapi_transcode.c 예제 포팅
13024정성태4/7/202215344.NET Framework: 1189. C# - 런타임 환경에 따라 달라진 AppDomain.GetCurrentThreadId 메서드
13023정성태4/6/202215920.NET Framework: 1188. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 transcoding.c 예제 포팅 [3]
13022정성태3/31/202215464Windows: 202. 윈도우 11 업그레이드 - "PC Health Check"를 통과했지만 여전히 업그레이드가 안 되는 경우 해결책
... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...