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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11908정성태5/22/201919854.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태5/22/201916586오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/201916813.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/201917371.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/201925746.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보 [1]파일 다운로드1
11903정성태5/21/201919573오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/201917746오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/201919636오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태5/18/201918575오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/201919425Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/16/201921228VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/201928213오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [2]
11896정성태5/15/201923105개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/201920974.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/10/201922691VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5]
11893정성태5/10/201919616오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/201919448웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/201922516.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/201917619개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/201918332개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/201935688.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1]파일 다운로드1
11887정성태5/8/201921271.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/7/201919132오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
11885정성태5/7/201916019오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생
11884정성태5/5/201920855.NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기
11883정성태5/3/201926049.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법파일 다운로드1
... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...