Microsoft MVP성태의 닷넷 이야기
Java: 5. WTP 내에서 서블릿을 실행하는 환경 [링크 복사], [링크+제목 복사],
조회: 27695
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

WTP 내에서 서블릿을 실행하는 환경

지난번 글의 마지막에서,

이클립스에서 서블릿 디버깅하는 방법
; https://www.sysnet.pe.kr/2/0/1118

서블릿이 컴파일된 .class 파일이 원래의 톰캣이 설치된 "\webapps\ROOT\WEB-INF\classes" 폴더에 배포되지 않은 것에 대해 의문점을 남겼는데요. 조금 공부하다 보니 답이 나오네요. ^^

일단, IIS Express에서 비슷한 사례를 한번 볼까요?

IIS Express - appcmd.exe를 이용한 applicationHost.config 변경
;  https://www.sysnet.pe.kr/2/0/1033

위의 글에서 보면, IIS Express는 원래의 설치 폴더가 있지만 /path 옵션을 통해서 Web Application의 루트를 재설정하는 것이 가능하죠. 마찬가지로 tomcat에도 그런 기능이 있는 것 같습니다. (제가 톰캣을 잘 몰라서 '가정'입니다.)

WTP에서 실행된 javaw.exe의 명령행 인자를 다시 보면 아래와 같고,

"E:\Program Files\Java\jre6\bin\javaw.exe" 
-Dcatalina.base=D:\Interop\Java\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0 
-Dcatalina.home=D:\servlet\tomcat 
-Dwtp.deploy=D:\Interop\Java\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps 
-Djava.endorsed.dirs=D:\servlet\tomcat\endorsed 
-Dfile.encoding=MS949 
-classpath D:\servlet\tomcat\bin\bootstrap.jar org.apache.catalina.startup.Bootstrap start 

"-D" 옵션은 일종의 명령행 파라미터를 전달하는 수단으로 보이고, 이를 정리하면 다음과 같습니다.

catalina.base = D:\Interop\Java\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0 
catalina.home = D:\servlet\tomcat 
wtp.deploy = D:\Interop\Java\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps 
java.endorsed.dirs = D:\servlet\tomcat\endorsed 
file.encoding = MS949 

위에서 톰캣이 설치된 폴더는 catalina.home 변수로 전달되고 있고, WTP가 구성한 본래의 tomcat 폴더를 재설정하는 임의의 폴더가 catalina.base 변수로 전달되는 것을 확인할 수 있습니다. tomcat 폴더 이외에 서블릿 컨테이너로써 서블릿들을 관리하는 폴더는 wtp.deploy로 넘어가고 있습니다.

IIS Express와 다소 억지로 비교하자면 아래와 같은 정도겠죠.

iisexpress.exe 가 위치한 폴더 == catalina.home 값
Web Application 폴더 == catalina.base 값
Web Application 폴더/bin 폴더 == wtp.deploy 값


참고로, catalina.base 값을 ASP.NET이라면, HttpRequest 타입의 PhysicalApplicationPath 속성값입니다.

계속해서, "D:\Interop\Java\workspace" 경로는 제가 이클립스에서 사용하도록 한 "Workspace"의 루트 경로입니다. 즉, WTP는 이클립스에 지정된 workspace 경로 하위에 '.\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps' 폴더를 만들고 그 하위에 서블릿을 배포하고 있습니다.

tomcat_override_path_1.png

부가적으로, WTP 내에서 실행된 서블릿의 "javax.servlet.context.tempdir" 문맥 변수의 값은 다음과 같습니다.

ServletContext ctx = this.getServletContext();
ctx.getAttribute("javax.servlet.context.tempdir")
 // tempdir == D:\Interop\Java\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\FirstServlet\ 

그런데, 상식적인 선에서 이해가 안되는 부분이 하나 있군요. 예를 들어, 서블릿에서 다음과 같이 경로를 지정하지 않고 파일을 생성하는 코드를 WTP 테스트 환경에서 실행하면,

public void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException
{
    FileWriter fileWriter = null;
    PrintWriter printWriter = null;
        
    try {
        fileWriter = new FileWriter("Init.log");
        printWriter = new PrintWriter(fileWriter);
        printWriter.println("test");
        return;
    }
    finally
    {
        if (printWriter != null)
        {
            printWriter.close();
        }
    }
}

파일이 어디 생성될까요? 제 예상은, catalina.base, wtp.deploy로 지정된 폴더이거나 tomcat의 원래 폴더라고 생각했는데, 엉뚱하게도 eclipse.exe 파일이 위치한 폴더였습니다. 이 경로는 System.getProperty("user.dir")로 구한 값과 일치하는데요. 이클립스가 톰캣 관련 EXE를 별도로 생성하는 것을 따져볼 때 환경 설정이 자식 EXE로 전달되어 이런 결과가 나오는 것 같습니다. 암튼... ^^ 자바의 개발환경을 이해하는 것이 쉽진 않은 것 같습니다. (아직 웹로직 같은 것도 들어가지 않았는데... 벌써 이 정도로 헤매고 있으니. ^^)




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

[연관 글]






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

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

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  143  [144]  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1454정성태5/31/201326285Java: 15. Java 7 Control Panel 실행시키는 방법
1453정성태5/22/201325329기타: 32. Microsoft FTP 사이트에 접속하는 방법
1452정성태5/21/201333039Windows: 73. TabProcGrowth 값 삭제 후 IE를 실행시키면 다시 복원되는 경우 [3]
1451정성태5/17/201331960Windows: 72. 윈도우 서버 2012 기초 사용법
1450정성태5/16/201322733오류 유형: 176. SQL10007N Message "0" could not be retrieved. Reason code: "3"
1449정성태5/15/201329842오류 유형: 175. SpeechRecognitionEngine 사용 시 오류 유형 2가지
1448정성태5/14/201324835VC++: 68. #pragma warning(disable: ...)로 오류 제어가 안된다면?
1447정성태5/3/201326519개발 환경 구성: 191. Debugging Tools for Windows 독립 설치 버전 [1]
1446정성태4/30/201327319.NET Framework: 368. Encoding 타입의 대체(fallback) 메카니즘 [1]
1445정성태4/26/201325538디버깅 기술: 54. NT 서비스의 Main 메서드 안에서 Process.GetProcessesByName 호출 시 멈춤 현상 [1]
1444정성태4/26/201329548기타: 31. Internet Explorer: 자바스크립트로 숨겨진 파일 다운로드 경로를 알아내는 방법 [1]
1443정성태4/24/201325227개발 환경 구성: 190. Azure PaaS 웹 응용 프로그램 배포 후 SMTP 서버 구성 [2]
1442정성태4/21/201328795기타: 30. 마이크로소프트 워드의 CPU 점유 현상으로 글자 입력이 느려졌다면? [1]
1441정성태4/21/201335401.NET Framework: 367. LargeAddressAware 옵션이 적용된 닷넷 32비트 프로세스의 가용 메모리 [14]
1440정성태4/19/201324131오류 유형: 174. dumpbin.exe 실행시 mspdb110.dll 로드 오류
1439정성태4/18/201327984VS.NET IDE: 76. Visual Studio 2012와 Itanium 빌드 옵션 [2]
1438정성태4/17/201327398.NET Framework: 366. 다른 프로세스에 환경 변수 설정하는 방법 - 두 번째 이야기 [1]파일 다운로드1
1437정성태4/17/201327623VC++: 67. CRT(C Runtime DLL: msvcr...dll)에 대한 의존성 제거
1436정성태4/17/201333007.NET Framework: 365. Local SYSTEM 권한으로 코드를 실행하는 방법파일 다운로드1
1435정성태4/15/201341889Windows: 71. ad-hoc 보다 더 편리한 "가상 Wifi" 를 이용한 인터넷 공유 [2]
1434정성태4/9/201323179오류 유형: 173. TFS 서버의 이벤트 로그 오류 - WebHost failed to process a request. Parameter name: certificate
1433정성태4/9/201323475개발 환경 구성: 189. TFS에 설치된 SharePoint 의 PowerShell 콘솔 띄우는 방법
1432정성태4/5/201324486오류 유형: 172. System.Web.PipelineModuleStepContainer.GetEventCount 에서 NullReferenceException 이 발생한다면?
1431정성태4/5/201325124기타: 29. 부팅 가능한 (외장) HDD를 기존 부팅 메뉴에 추가하는 방법
1430정성태4/4/201326993제니퍼 .NET: 23. 모바일용 웹 사이트에서 발생하는 응답 시간 지연 현상 [5]파일 다운로드1
1429정성태3/29/201323357개발 환경 구성: 188. SCOM 2012 - ASP.NET 모니터링 방법
... 136  137  138  139  140  141  142  143  [144]  145  146  147  148  149  150  ...