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

비밀번호

댓글 작성자
 




... [46]  47  48  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12476정성태1/5/202110280.NET Framework: 996. C# - 닷넷 코어에서 다른 스레드의 callstack을 구하는 방법파일 다운로드1
12475정성태1/5/202112863.NET Framework: 995. C# - Span<T>와 Memory<T> [1]파일 다운로드1
12474정성태1/4/202110394.NET Framework: 994. C# - (.NET Core 2.2부터 가능한) 프로세스 내부에서 CLR ETW 이벤트 수신 [1]파일 다운로드1
12473정성태1/4/20219205.NET Framework: 993. .NET 런타임에 따라 달라지는 정적 필드의 초기화 유무 [1]파일 다운로드1
12472정성태1/3/20219483디버깅 기술: 178. windbg - 디버그 시작 시 스크립트 실행
12471정성태1/1/20219974.NET Framework: 992. C# - .NET Core 3.0 이상부터 제공하는 runtimeOptions의 rollForward 옵션 [1]
12470정성태12/30/202010131.NET Framework: 991. .NET 5 응용 프로그램에서 WinRT API 호출 [1]파일 다운로드1
12469정성태12/30/202013724.NET Framework: 990. C# - SendInput Win32 API를 이용한 가상 키보드/마우스 [1]파일 다운로드1
12468정성태12/30/202010340Windows: 186. CMD Shell의 "Defaults"와 "Properties"에서 폰트 정보가 다른 문제 [1]
12467정성태12/29/202010241.NET Framework: 989. HttpContextAccessor를 통해 이해하는 AsyncLocal<T> [1]파일 다운로드1
12466정성태12/29/20208236.NET Framework: 988. C# - 지연 실행이 꼭 필요한 상황이 아니라면 singleton 패턴에서 DCLP보다는 static 초기화를 권장파일 다운로드1
12465정성태12/29/202011371.NET Framework: 987. .NET Profiler - FunctionID와 연관된 ClassID를 구할 수 없는 문제
12464정성태12/29/202010210.NET Framework: 986. pptfont.exe - PPT 파일에 숨겨진 폰트 설정을 일괄 삭제
12463정성태12/29/20209261개발 환경 구성: 520. RDP(mstsc.exe)의 다중 모니터 옵션 /multimon, /span
12462정성태12/27/202010891디버깅 기술: 177. windbg - (ASP.NET 환경에서 유용한) netext 확장
12461정성태12/21/202011714.NET Framework: 985. .NET 코드 리뷰 팁 [3]
12460정성태12/18/20209415기타: 78. 도서 소개 - C#으로 배우는 암호학
12459정성태12/16/20209816Linux: 35. C# - 리눅스 환경에서 클라이언트 소켓의 ephemeral port 재사용파일 다운로드1
12458정성태12/16/20209309오류 유형: 694. C# - Task.Start 메서드 호출 시 "System.InvalidOperationException: 'Start may not be called on a task that has completed.'" 예외 발생 [1]
12457정성태12/15/20208866Windows: 185. C# - Windows 10/2019부터 추가된 SIO_TCP_INFO파일 다운로드1
12456정성태12/15/20209141VS.NET IDE: 156. Visual Studio - "Migrate packages.config to PackageReference"
12455정성태12/15/20208663오류 유형: 693. DLL 로딩 시 0x800704ec - This Program is Blocked by Group Policy
12454정성태12/15/20209231Windows: 184. Windows - AppLocker의 "DLL Rules"를 이용해 임의 경로에 설치한 DLL의 로딩을 막는 방법 [1]
12453정성태12/14/202010213.NET Framework: 984. C# - bool / BOOL / VARIANT_BOOL에 대한 Interop [1]파일 다운로드1
12452정성태12/14/202010418Windows: 183. 설정은 가능하지만 구할 수는 없는 TcpTimedWaitDelay 값
12451정성태12/14/20209589Windows: 182. WMI Namespace를 열거하고, 그 안에 정의된 클래스를 열거하는 방법 [5]
... [46]  47  48  49  50  51  52  53  54  55  56  57  58  59  60  ...