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

비주얼 스튜디오에서 실행하던 ASP.NET Core (.NET Framework) 응용 프로그램을 명령행에서 실행하는 방법

비주얼 스튜디오에서 ASP.NET Core (.NET Framework) 응용 프로그램을 F5 키로 실행하면 기본적으로 iisexpress 위에서 호스팅이 됩니다. 그리고 이때의 명령행을 Process Explorer와 같은 도구로 이용해 보면 다음과 같은 구성을 확인할 수 있습니다.

명령어: "C:\Program Files\IIS Express\iisexpress.exe"  /config:"D:\core_web_app\.vs\config\applicationhost.config" /site:"fullnet_mvc_core" /apppool:"Clr4IntegratedAppPool"

기본 디렉터리: C:\Program Files\IIS Express\

그럼, 명령행에서도 저렇게 실행하면 될까요? 실제로 해보면 웹 페이지 방문 시 "HTTP Error 502.5 - Process Failure" 오류가 발생하면서 웹 브라우저에는 다음과 같은 내용이 출력됩니다.

Common causes of this issue:

    The application process failed to start
    The application process started but then stopped
    The application process started but failed to listen on the configured port

Troubleshooting steps:

    Check the system event log for error messages
    Enable logging the application process' stdout messages
    Attach a debugger to the application process and inspect

이와 함께 이벤트 로그에는 다음의 항목이 남습니다.

Log Name:      Application
Source:        IIS Express AspNetCore Module
Date:          2017-12-08 오후 1:52:04
Event ID:      1000
Task Category: None
Level:         Error
Keywords:      Classic
User:          N/A
Computer:      TESTPC
Description:
Application 'MACHINE/WEBROOT/APPHOST/FULLNET_MVC_CORE' with physical root 'D:\core_web_app\fullnet_mvc_core\' failed to start process with commandline '%LAUNCHER_PATH% %LAUNCHER_ARGS%', ErrorCode = '0x80070002 : 0.

LAUNCHER_ARGS -argFile "%LOCALAPPDATA%\Temp\tmpD26f.tmp"
LAUNCHER_PATH "C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\Microsoft\Web Tools\ProjectSystem\VSIISExeLauncher.exe"

위의 내용인즉, iisexpress.exe는 단순히 중계 프로세스일 뿐 별도로 iisexpress의 자식 프로세스로 VSIISExeLauncher.exe를 다음과 같은 인자 구성으로 실행시키는 역할을 합니다.

"C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\Microsoft\Web Tools\ProjectSystem\VSIISExeLauncher.exe" -argFile "%LOCALAPPDATA%\Temp\tmpD26f.tmp"


이때 전달된 "%LOCALAPPDATA%\Temp\tmpD26f.tmp" 파일의 내용을 보면 다음과 같습니다.

// tmpD26f.tmp 파일 내용

-p D:\core_web_app\fullnet_mvc_core\bin\Debug\net47\fullnet_mvc_core.exe
-pidFile %LOCALAPPDATA%\Temp\tmpD26E.tmp
-wd D:\core_web_app\fullnet_mvc_core
-a
-pipe 66c2131a-6df7-4835-a3cc-241eacba2f27
-pr fullnet_mvc_core
-owningPid 30008
-env ASPNETCORE_CONTENTROOT=D:\core_web_app\fullnet_mvc_core|ASPNETCORE_ENVIRONMENT=Development|COMPLUS_ForceENC=1|

그리고 다시 전달되는 -pidFile 파일은 그 안에 "pid:31564"와 같은 식의 Process ID를 포함합니다. 즉, VSIISExeLauncher.exe 역시 중계 프로세스일 뿐 사실상 ASP.NET Core를 호스팅하는 프로세스는 bin\Debug\net47\fullnet_mvc_core.exe인 것입니다.

따라서... 결과가 좀 허무하지만, 그냥 명령행에서 fullnet_mvc_core.exe라고 실행하면 잘 동작하는 것입니다. ^^

명령어: "D:\core_web_app\fullnet_mvc_core\bin\Debug\net47\fullnet_mvc_core.exe" 
기본 디렉터리: D:\core_web_app\fullnet_mvc_core\




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

[연관 글]






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

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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  [102]  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11379정성태11/30/201718971오류 유형: 435. System.Web.HttpException - Session state has created a session id, but cannot save it because the response was already flushed by the application.
11378정성태11/29/201720456.NET Framework: 701. 한글이 포함된 바이트 배열을 나눈 경우 한글이 깨지지 않도록 다시 조합하는 방법 [1]파일 다운로드1
11377정성태11/29/201719664.NET Framework: 700. CommonOpenFileDialog 사용 시 사용자가 선택한 파일 목록을 구하는 방법 [3]파일 다운로드1
11376정성태11/28/201724018VS.NET IDE: 123. Visual Studio 편집기의 \r\n (crlf) 개행을 \n으로 폴더 단위로 설정하는 방법
11375정성태11/28/201718878오류 유형: 434. Visual Studio로 ASP.NET 디버깅 중 System.Web.HttpException - Could not load type 오류
11374정성태11/27/201723901사물인터넷: 14. 라즈베리 파이 - (윈도우의 NT 서비스처럼) 부팅 시 시작하는 프로그램 설정 [1]
11373정성태11/27/201722926오류 유형: 433. Raspberry Pi/Windows 다중 플랫폼 지원 컴파일 관련 오류 기록
11372정성태11/25/201725944사물인터넷: 13. 윈도우즈 사용자를 위한 라즈베리 파이 제로 W 모델을 설정하는 방법 [4]
11371정성태11/25/201719630오류 유형: 432. Hyper-V 가상 스위치 생성 시 Failed to connect Ethernet switch port 0x80070002 오류 발생
11370정성태11/25/201719489오류 유형: 431. Hyper-V의 Virtual Switch 생성 시 "External network" 목록에 특정 네트워크 어댑터 항목이 없는 경우
11369정성태11/25/201721621사물인터넷: 12. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 키보드 및 마우스로 쓰는 방법 (절대 좌표, 상대 좌표, 휠) [1]
11368정성태11/25/201727236.NET Framework: 699. UDP 브로드캐스트 주소 255.255.255.255와 192.168.0.255의 차이점과 이를 고려한 C# UDP 서버/클라이언트 예제 [2]파일 다운로드1
11367정성태11/25/201727256개발 환경 구성: 337. 윈도우 운영체제의 route 명령어 사용법
11366정성태11/25/201718906오류 유형: 430. 이벤트 로그 - Cryptographic Services failed while processing the OnIdentity() call in the System Writer Object.
11365정성태11/25/201721157오류 유형: 429. 이벤트 로그 - User Policy could not be updated successfully
11364정성태11/24/201722979사물인터넷: 11. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 마우스로 쓰는 방법 (절대 좌표) [2]
11363정성태11/23/201723025사물인터넷: 10. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 마우스 + 키보드로 쓰는 방법 (두 번째 이야기)
11362정성태11/22/201719561오류 유형: 428. 윈도우 업데이트 KB4048953 - 0x800705b4 [2]
11361정성태11/22/201722399오류 유형: 427. 이벤트 로그 - Filter Manager failed to attach to volume '\Device\HarddiskVolume??' 0xC03A001C
11360정성태11/22/201722159오류 유형: 426. 이벤트 로그 - The kernel power manager has initiated a shutdown transition.
11359정성태11/16/201721652오류 유형: 425. 윈도우 10 Version 1709 (OS Build 16299.64) 업그레이드 시 발생한 문제 2가지
11358정성태11/15/201726353사물인터넷: 9. Visual Studio 2017에서 Raspberry Pi C++ 응용 프로그램 제작 [1]
11357정성태11/15/201726788개발 환경 구성: 336. 윈도우 10 Bash 쉘에서 C++ 컴파일하는 방법
11356정성태11/15/201728430사물인터넷: 8. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 마우스 + 키보드로 쓰는 방법 [4]
11355정성태11/15/201724327사물인터넷: 7. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 마우스로 쓰는 방법 [2]파일 다운로드2
11354정성태11/14/201728534사물인터넷: 6. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 키보드로 쓰는 방법 [8]
... 91  92  93  94  95  96  97  98  99  100  101  [102]  103  104  105  ...