Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio - .NET Core App 실행 시 dotnet.exe 실행 화면만 나오는 문제

이상하군요, Visual Studio에서 .NET Core 프로젝트를 F5 또는 Ctrl + F5로 실행하면 화면에 다음과 같은 dotnet.exe 실행 문구만 나오고 종료됩니다.

Usage: dotnet [options]
Usage: dotnet [path-to-application]

Options:
  -h|--help         Display help.
  --info            Display .NET information.
  --list-sdks       Display the installed SDKs.
  --list-runtimes   Display the installed runtimes.

path-to-application:
  The path to an application .dll file to execute.

C:\Program Files (x86)\dotnet\dotnet.exe (process 25636) exited with code -2147450751.
Press any key to close this window . . .

실제로 sysmon으로 확인해 보면 다음과 같이 VsDebugConsole.exe 측에서 "dotnet.exe"를 실행시키지만 별다른 명령행 인자가 없어 그대로 사용법만 출력한 채 종료하는 것입니다.

Process Create:
UtcTime: 2020-11-22 05:46:39.789
ProcessGuid: {dc8344f7-efbf-5fbd-0000-00104aa7150c}
ProcessId: 20204
Image: C:\Program Files (x86)\dotnet\dotnet.exe
CommandLine: "C:\Program Files (x86)\dotnet\dotnet.exe"
CurrentDirectory: F:\temp\ConsoleApp1\CoreApp\bin\x86\Debug\netcoreapp3.1\
...[생략]...
ParentProcessId: 34892
ParentImage: C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\IDE\CommonExtensions\Platform\Debugger\VsDebugConsole.exe
ParentCommandLine: "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\IDE\CommonExtensions\Platform\Debugger\VsDebugConsole.exe" \\.\pipe\Microsoft-VisualStudio-Debug-Console-20172 Local\{9DF33177-D378-414D-BF40-DCD733B93FEC}

재미있는 것은, 지금까지 잘 사용했었는데 어느 순간 저렇게 나온 것인데요, 다행히 과거 자료에서 힌트를 얻었습니다. ^^;

.NET Core 프로젝트를 Visual Studio에서 실행 시 System.BadImageFormatException 발생하는 경우
; https://www.sysnet.pe.kr/2/0/11545

Visual Studio에서 ASP.NET Core 실행할 때 dotnet.exe 프로세스의 -532462766 오류 발생
; https://www.sysnet.pe.kr/2/0/11244

그러니까, 문제의 원인은 저 글을 쓸 당시 테스트한다고 F:\ 루트에 "Directory.Build.targets"을 넣은 후 .NET Core 2.x까지는 잘 실행이 되었지만 3.x부터 dll이 아닌 exe 출력 파일을 실행하면서부터 저 설정이 비주얼 스튜디오의 실행을 방해한 것입니다. 게다가, 다른 디렉터리에 있던 프로젝트들은 f:\Directory.Build.targets 파일의 영향을 받지 않아 실행이 잘 되었던 것이고. ^^;

그런 의미에서 봤을 때 Directory.Build.targets 파일은 귀찮다고 해서 부모 디렉터리에 넣어두기보다는 .NET Core 2.x 이하에 한해 프로젝트 디렉터리에 직접 넣어두는 것이 바람직하겠습니다. 혹은, Directory.Build.targets의 조건에 (현재 .NET Core 1.x 버전은 거의 안 쓰니) .NET Core 2.x인 경우에만 dotnet.exe를 경유하도록 조건을 넣어두면 됩니다.

<Project>
  <PropertyGroup 
      Condition="'$(OS)' == 'Windows_NT' and
                 '$(TargetFrameworkIdentifier)' == '.NETCoreApp' and
                 ( 
                      '$(TargetFramework)' == 'netcoreapp2.0' or
                      '$(TargetFramework)' == 'netcoreapp2.1' or
                      '$(TargetFramework)' == 'netcoreapp2.2' 
                 ) and
                 '$(SelfContained)' != 'true'"
                  >
    <RunCommand Condition="'$(PlatformTarget)' == 'x86'">$(MSBuildProgramFiles32)\dotnet\dotnet</RunCommand>
    <RunCommand Condition="'$(PlatformTarget)' == 'x64'">$(ProgramW6432)\dotnet\dotnet</RunCommand>
  </PropertyGroup>
</Project>




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







[최초 등록일: ]
[최종 수정일: 11/25/2020]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  116  [117]  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11036정성태8/29/201625836개발 환경 구성: 297. 소스 코드가 없는 닷넷 어셈블리를 디버깅할 때 지역 변숫값을 확인하는 방법
11035정성태8/29/201621768오류 유형: 354. .NET Reflector - PDB 생성 화면에서 "Clear Store"를 하면 "Index and length must refer to a location within the string" 예외 발생
11034정성태8/25/201625841개발 환경 구성: 296. .NET Core 프로젝트를 NuGet Gallery에 배포하는 방법 [2]
11033정성태8/24/201623817오류 유형: 353. coreclr 빌드 시 error C3249: illegal statement or sub-expression for 'constexpr' function
11032정성태8/23/201623025개발 환경 구성: 295. 최신의 Visual C++ 컴파일러 도구를 사용하는 방법 [1]
11031정성태8/23/201618992오류 유형: 352. Error encountered while pushing to the remote repository: Response status code does not indicate success: 403 (Forbidden).
11030정성태8/23/201622210VS.NET IDE: 111. Team Explorer - 추가한 Git Remote 저장소가 Branch에 보이지 않는 경우
11029정성태8/18/201629509.NET Framework: 602. Process.Start의 cmd.exe에서 stdin만 redirect 하는 방법 [1]파일 다운로드1
11028정성태8/15/201622464오류 유형: 351. Octave 설치 시 JRE 경로 문제
11027정성태8/15/201624256.NET Framework: 601. ElementHost 컨트롤의 메모리 누수 현상
11026정성태8/13/201625409Math: 19. 행렬 연산으로 본 해밍코드
11025정성태8/12/201624333개발 환경 구성: 294. .NET Core 프로젝트에서 "Copy to Output Directory" 처리 [1]
11024정성태8/12/201623445오류 유형: 350. "nProtect GameMon" 실행 중에는 Visual Studio 디버깅이 안됩니다! [1]
11023정성태8/10/201625036개발 환경 구성: 293. Azure 구독 후 PaaS 서비스 만들어 보기
11022정성태8/10/201625704개발 환경 구성: 292. Azure Cloud Service 배포시 사용자 정의 작업을 추가하는 방법
11021정성태8/10/201622825오류 유형: 349. System.Runtime.Remoting.RemotingException - Type '..., ..., Version=..., Culture=neutral, PublicKeyToken=null' is not registered for activation [2]
11020정성태8/10/201625737VC++: 98. 원본과 대상 버퍼가 같은 경우 memcpy, wmemcpy 주의점
11019정성태8/10/201642338기타: 60. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 (2쇄 정오표)
11018정성태8/9/201626441.NET Framework: 600. 단일 메서드 내에서의 할당으로 알아보는 자바와 닷넷의 GC 차이점 [1]
11017정성태8/9/201627721웹: 33. HTTP 쿠키에 한글 값을 설정하는 방법
11016정성태8/7/201625909개발 환경 구성: 291. Windows Server Containers 소개
11015정성태8/7/201624226오류 유형: 348. Windows Server 2016 TP5에서 Windows Containers의 docker run 실행 시 encountered an error during Start failed in Win32
11014정성태8/6/201624937오류 유형: 347. Hyper-V Virtual Machine Management service Account does not have permission to open attachment
11013정성태8/6/201635775개발 환경 구성: 290. Windows 10에서 경험해 보는 Windows Containers와 docker [4]
11012정성태8/6/201625856오류 유형: 346. Windows 10에서 Windows Containers의 docker run 실행 시 encountered an error during CreateContainer failed in Win32 발생
11011정성태8/6/201627305기타: 59. outlook.live.com 메일 서비스의 아웃룩 POP3 설정하는 방법
... 106  107  108  109  110  111  112  113  114  115  116  [117]  118  119  120  ...