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)
12360정성태10/8/20208274오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
12359정성태10/7/20209814오류 유형: 665. Windows - 재부팅 후 iSCSI 연결이 끊기는 문제
12358정성태10/7/20209835오류 유형: 664. Web Deploy 설치 시 "A newer version of Microsoft Web Deploy 3.6 was found on this machine." 오류 [3]
12357정성태10/7/20207912오류 유형: 663. 이벤트 로그 - The storage optimizer couldn't complete retrim on New Volume
12356정성태10/7/202022811오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
12355정성태10/3/20207988오류 유형: 661. Hyper-V Linux VM의 Internal 유형의 가상 Switch에 대한 IP 연결이 되지 않는 경우
12354정성태10/2/202020908오류 유형: 660. Web Deploy (msdeploy.axd) 실행 시 오류 기록 [1]
12353정성태10/2/202010698개발 환경 구성: 518. 비주얼 스튜디오에서 IIS 웹 서버로 "Web Deploy"를 이용해 배포하는 방법
12352정성태10/2/202011150개발 환경 구성: 517. Hyper-V Internal 네트워크에 NAT을 이용한 인터넷 연결 제공
12351정성태10/2/202010691오류 유형: 659. Nox 실행이 안 되는 경우 - Unable to bind to the underlying transport for ...
12350정성태9/25/202014189Windows: 175. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 [2]파일 다운로드1
12349정성태9/25/20209088Linux: 32. Ubuntu 20.04 - docker를 위한 tcp 바인딩 추가
12348정성태9/25/20209792오류 유형: 658. 리눅스 docker - Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock
12347정성태9/25/202023960Windows: 174. WSL 2의 네트워크 통신 방법 [4]
12346정성태9/25/20209025오류 유형: 657. IIS - http://localhost 방문 시 Service Unavailable 503 오류 발생
12345정성태9/25/20208762오류 유형: 656. iisreset 실행 시 "Restart attempt failed." 오류가 발생하지만 웹 서비스는 정상적인 경우파일 다운로드1
12344정성태9/25/20209926Windows: 173. 서비스 관리자에 "IIS Admin Service"가 등록되어 있지 않다면?
12343정성태9/24/202019531.NET Framework: 945. C# - 닷넷 응용 프로그램에서 메모리 누수가 발생할 수 있는 패턴 [5]
12342정성태9/24/202010839디버깅 기술: 171. windbg - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법
12341정성태9/23/20209922.NET Framework: 944. C# - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법파일 다운로드1
12340정성태9/23/20209674.NET Framework: 943. WPF - WindowsFormsHost를 담은 윈도우 생성 시 메모리 누수
12339정성태9/21/20209671오류 유형: 655. 코어 모드의 윈도우는 GUI 모드의 윈도우로 교체가 안 됩니다.
12338정성태9/21/20209220오류 유형: 654. 우분투 설치 시 "CHS: Error 2001 reading sector ..." 오류 발생
12337정성태9/21/202010567오류 유형: 653. Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
12336정성태9/21/202013064.NET Framework: 942. C# - WOL(Wake On Lan) 구현
12335정성태9/21/202022411Linux: 31. 우분투 20.04 초기 설정 - 고정 IP 및 SSH 설치
... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...