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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12375정성태10/15/20209794Windows: 177. 윈도우 탐색기에서 띄우는 cmd.exe 창의 디렉터리 구분 문자가 'Yen(&#0165;)' 기호로 나오는 경우 [1]
12374정성태10/14/202014434.NET Framework: 953. C# 9.0 - (6) 함수 포인터(Function pointers) [1]파일 다운로드2
12373정성태10/14/20209700.NET Framework: 952. OpCodes.Box와 관련해 IL 형식으로 직접 코딩 시 유의할 점
12372정성태10/13/202011505.NET Framework: 951. C# 9.0 - (5) 로컬 함수에 특성 지정 가능(Attributes on local functions)파일 다운로드1
12371정성태10/13/202010322개발 환경 구성: 519. Visual Studio의 Ctrl+Shift+U (Edit.MakeUppercase) 단축키가 동작하지 않는 경우
12370정성태10/13/202011210Linux: 33. Linux - nmcli를 이용한 고정 IP 설정
12369정성태10/12/202014008Windows: 176. Raymond Chen이 한글날에 밝히는 윈도우의 한글 자모 분리 현상 [3]
12368정성태10/12/202010066오류 유형: 668. VSIX 확장 빌드 - The "GetDeploymentPathFromVsixManifest" task failed unexpectedly.
12367정성태10/12/202022850오류 유형: 667. Ubuntu - Temporary failure resolving 'kr.archive.ubuntu.com' [2]
12366정성태10/12/202011806.NET Framework: 950. C# 9.0 - (4) 원시 크기 정수(Native ints) [1]파일 다운로드1
12365정성태10/12/202010680.NET Framework: 949. C# 9.0 - (3) 람다 메서드의 매개 변수 무시(Lambda discard parameters)파일 다운로드1
12364정성태10/11/202011903.NET Framework: 948. C# 9.0 - (2) localsinit 플래그 내보내기 무시(Suppress emitting localsinit flag)파일 다운로드1
12363정성태10/11/202012840.NET Framework: 947. C# 9.0 - (1) 대상으로 형식화된 new 식(Target-typed new expressions) [2]파일 다운로드1
12362정성태10/11/20209623VS.NET IDE: 151. Visual Studio 2019에 .NET 5 rc/preview 적용하는 방법
12361정성태10/11/202011268.NET Framework: 946. C# 9.0을 위한 개발 환경 구성
12360정성태10/8/20208426오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
12359정성태10/7/20209970오류 유형: 665. Windows - 재부팅 후 iSCSI 연결이 끊기는 문제
12358정성태10/7/20209999오류 유형: 664. Web Deploy 설치 시 "A newer version of Microsoft Web Deploy 3.6 was found on this machine." 오류 [3]
12357정성태10/7/20208039오류 유형: 663. 이벤트 로그 - The storage optimizer couldn't complete retrim on New Volume
12356정성태10/7/202023028오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
12355정성태10/3/20208129오류 유형: 661. Hyper-V Linux VM의 Internal 유형의 가상 Switch에 대한 IP 연결이 되지 않는 경우
12354정성태10/2/202021076오류 유형: 660. Web Deploy (msdeploy.axd) 실행 시 오류 기록 [1]
12353정성태10/2/202010898개발 환경 구성: 518. 비주얼 스튜디오에서 IIS 웹 서버로 "Web Deploy"를 이용해 배포하는 방법
12352정성태10/2/202011399개발 환경 구성: 517. Hyper-V Internal 네트워크에 NAT을 이용한 인터넷 연결 제공
12351정성태10/2/202010915오류 유형: 659. Nox 실행이 안 되는 경우 - Unable to bind to the underlying transport for ...
12350정성태9/25/202014404Windows: 175. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 [2]파일 다운로드1
... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...