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

dotnet.exe - 윈도우 운영체제에서의 .NET Core 버전 찾기 규칙

.NET Core를 설치하면, 환경 변수 PATH에 dotnet.exe에 대한 경로가 추가됩니다.

[x64 .NET Core]
    C:\Program Files\dotnet\

[x86 .NET Core]
    C:\Program Files (x86)\dotnet\

Visual Studio 2017 명령행으로 "dotnet.exe"를 실행하면 다음과 같은 결과를 볼 수 있는데요.

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>dotnet

Microsoft .NET Core Shared Framework Host

  Version  : 1.1.0
  Build    : 928f77c4bc3f49d892459992fb6e1d5542cb5e86

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

Common Options:
  --help                           Display .NET Core Shared Framework Host help.
  --version                        Display .NET Core Shared Framework Host version.

Options:
  --fx-version <version>           Version of the installed Shared Framework to use to run the application.
  --additionalprobingpath <path>   Path containing probing policy and assemblies to probe for.

Path to Application:
  The path to a .NET Core managed application, dll or exe file to execute.

If you are debugging the Shared Framework Host, set 'COREHOST_TRACE' to '1' in your environment.

To get started on developing applications for .NET Core, install the SDK from:
  http://go.microsoft.com/fwlink/?LinkID=798306&clcid=0x409

설명에 보면 "COREHOST_TRACE"라는 옵션이 보입니다. 실제로 이를 설정하고 dotnet.exe를 다시 실행해 보면,

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>SET COREHOST_TRACE=1

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>dotnet
Tracing enabled
--- Invoked dotnet [version: 1.1.0, commit hash: 928f77c4bc3f49d892459992fb6e1d5542cb5e86] main = {
dotnet
}
Reading fx resolver directory=[C:\Program Files\dotnet\host\fxr]
Considering fxr version=[.]...
Considering fxr version=[..]...
Considering fxr version=[1.0.5]...
Considering fxr version=[1.1.2]...
Detected latest fxr version=[C:\Program Files\dotnet\host\fxr\1.1.2]...
Resolved fxr [C:\Program Files\dotnet\host\fxr\1.1.2\hostfxr.dll]...
Loaded library from C:\Program Files\dotnet\host\fxr\1.1.2\hostfxr.dll
Tracing enabled
--- Invoked hostfxr [commit hash: 928f77c4bc3f49d892459992fb6e1d5542cb5e86] main
Own DLL path=[C:\Program Files\dotnet\dotnet.dll]
Checking if CoreCLR path exists=[C:\Program Files\dotnet\coreclr.dll]
--- Executing in muxer mode...

Microsoft .NET Core Shared Framework Host

  Version  : 1.1.0
  Build    : 928f77c4bc3f49d892459992fb6e1d5542cb5e86
...[생략]...

시스템에 설치된 .NET Core의 버전 목록이 출력됩니다. 위의 경우에는 1.0.5, 1.1.2 버전의 .NET Core가 설치되어 있으며 각각의 버전에 따라 다음의 폴더에 hostfxr.dll 파일을 포함하고 있습니다.

C:\Program Files\dotnet\host\fxr\1.0.5
C:\Program Files\dotnet\host\fxr\1.1.2

물론, 저 경로는 hostfxr.dll만 포함하고 있기 때문에 실질적인 버전 별 .NET Core 파일들은 각각의 버전에 따라 다음과 같이 별도로 분리되어 있습니다.

C:\Program Files\dotnet\shared\Microsoft.NETCore.App\1.0.5
C:\Program Files\dotnet\shared\Microsoft.NETCore.App\1.1.2

그러니까, "C:\Program Files\dotnet" 폴더에 있는 dotnet.exe는 일종의 shim 역할을 프로그램입니다. 이 때문에, 여러분들이 .NET Core 1.0으로 프로그램을 작성했든 1.1로 작성을 했든 상관없이 다음과 같은 명령어로 실행할 수 있습니다.

"C:\Program Files\dotnet\dotnet.exe" test.dll

dotnet.exe는 인자로 넘어온 test.dll 파일의 TargetFramework 특성을 보고,

[assembly: TargetFramework(".NETCoreApp,Version=v1.1", FrameworkDisplayName="")]

".NETCoreApp,Version=v1.1"과 같이 지정된 버전에 맞는 .NET Core 런타임을 찾아서 로드해 주는 역할을 합니다.




dotnet.exe의 버전 찾기 규칙을 알았으니 이제 dotnet.exe 실행 관련 오동작 사례를 하나 살펴보겠습니다.

ASP.NET Core 1.1 프로젝트를 생성하고 (아무 작업도 하지 않았는데도) 실행했을 때, Output 윈도우에 다음과 같은 내용만 출력될 뿐 디버깅이나 실행이 전혀 안되는 경우가 있습니다.

The program '[9496] dotnet.exe' has exited with code -2147450749 (0x80008083).
The program '[9496] dotnet.exe: Program Trace' has exited with code 0 (0x0).
The program '[27308] iisexpress.exe: Program Trace' has exited with code 0 (0x0).
The program '[27308] iisexpress.exe' has exited with code 0 (0x0).

Visual Studio에서 dotnet.exe를 어떻게 실행하는지 알아보기 위해 sysmon을 구동시켜 dotnet.exe 실행 환경을 알아낼 수 있고,

"C:\Program Files (x86)\dotnet\dotnet.exe" exec "C:\temp\WebApplication1\WebApplication1\bin\Debug\netcoreapp1.1\WebApplication1.dll"

실제로 명령행을 띄워 위의 결과 그대로 실행해 보면, 다음과 같은 출력과 함께 ERRORLEVEL도 -2147450749 값으로 Visual Studio의 출력과 동일합니다.

C:\temp\WebApplication1>"C:\Program Files (x86)\dotnet\dotnet.exe" exec "C:\temp\WebApplication1\WebApplication1\bin\Debug\netcoreapp1.1\WebApplication1.dll"

The specified framework 'Microsoft.NETCore.App', version '1.1.2' was not found.
  - Check application dependencies and target a framework version installed at:
      C:\Program Files (x86)\dotnet\shared\Microsoft.NETCore.App
  - The following versions are installed:
      1.0.4
      1.1.1
  - Alternatively, install the framework version '1.1.2'.

C:\temp\WebApplication1>echo %ERRORLEVEL%
-2147450749

위의 출력 결과를 보면, 1.0.4, 1.1.1 버전은 찾았으나 제가 생성한 ASP.NET Core 1.1에서 지정한 "1.1.2" 버전의 .NET Core는 찾을 수 없다는 것입니다. 따라서 지정된 버전의 런타임을 추가적으로 설치해 주면,

.NET Core Runtime and SDK download archive
; https://github.com/dotnet/core/blob/master/release-notes/download-archive.md

원하는 1.1.2 버전이 dotnet.exe에 의해 검색이 되고,

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>SET COREHOST_TRACE=1

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>dotnet
Tracing enabled
--- Invoked dotnet [version: 1.1.0, commit hash: 928f77c4bc3f49d892459992fb6e1d5542cb5e86] main = {
dotnet
}
Reading fx resolver directory=[C:\Program Files (x86)\dotnet\host\fxr]
Considering fxr version=[.]...
Considering fxr version=[..]...
Considering fxr version=[1.0.5]...
Considering fxr version=[1.1.0]...
Considering fxr version=[1.1.2]...
Detected latest fxr version=[C:\Program Files (x86)\dotnet\host\fxr\1.1.2]...
Resolved fxr [C:\Program Files (x86)\dotnet\host\fxr\1.1.2\hostfxr.dll]...
Loaded library from C:\Program Files (x86)\dotnet\host\fxr\1.1.2\hostfxr.dll
Tracing enabled
--- Invoked hostfxr [commit hash: 928f77c4bc3f49d892459992fb6e1d5542cb5e86] main
Own DLL path=[C:\Program Files (x86)\dotnet\dotnet.dll]
Checking if CoreCLR path exists=[C:\Program Files (x86)\dotnet\coreclr.dll]
--- Executing in muxer mode...

이제부터 실행도 잘 됩니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 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)
11198정성태5/10/201722664.NET Framework: 656. Windows Forms의 오류(Exception) 처리 방법에 대한 차이점 설명
11197정성태5/8/201719481개발 환경 구성: 315. VHD 파일의 최소 크기파일 다운로드1
11196정성태5/4/201720680오류 유형: 384. Msvm_ImageManagementService WMI 객체를 사용할 때 오류 상황 정리 [1]
11195정성태5/3/201720989.NET Framework: 655. .NET Framework 4.7 릴리스
11194정성태5/3/201723257오류 유형: 383. net use 명령어로 네트워크 드라이브 연결 시 "System error 67 has occurred." 오류 발생
11193정성태5/3/201721483Windows: 141. 설치된 Windows로부터 설치 이미지를 만드는 방법
11192정성태5/2/201722017Windows: 140. unattended.xml/autounattend.xml 파일을 마련하는 방법
11191정성태5/2/201722783Windows: 139. Dell Venue 8 Pro 태블릿에 USB를 이용한 윈도우 운영체제 설치 방법
11190정성태5/2/201728130Windows: 138. Windows 운영체제의 ISO 설치 파일에 미리 Device driver를 준비하는 방법
11189정성태5/2/201720137Windows: 137. Windows 7 USB/DVD DOWNLOAD TOOL로 98%에서 실패하는 경우
11188정성태4/27/201722660VC++: 118. Win32 HANDLE 자료형의 이모저모 [1]
11187정성태4/26/201723200개발 환경 구성: 314. C# - PowerPoint 확장 Add-in 만드는 방법 [1]파일 다운로드1
11186정성태4/24/201720982VS.NET IDE: 117. Visual Studio 확장(VSIX)을 이용해 사용자 매크로를 추가하는 방법 [1]파일 다운로드1
11185정성태4/22/201718934VS.NET IDE: 116. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법 (2) - 동적 메뉴 구성파일 다운로드1
11184정성태4/21/201720447VS.NET IDE: 115. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법파일 다운로드1
11183정성태4/19/201719250.NET Framework: 654. UWP 앱에서 FolderPicker 사용 시 유의 사항파일 다운로드1
11182정성태4/19/201723294개발 환경 구성: 313. Nuget Facebook 라이브러리를 이용해 ASP.NET 웹 폼과 로그인 연동하는 방법
11181정성태4/18/201720247개발 환경 구성: 312. Azure Web Role의 AppPool 실행 권한을 Local System으로 바꾸는 방법
11180정성태4/16/201723282Java: 18. Java의 Memory Mapped File 자원 반환이 안 되는 문제
11179정성태4/13/201716474기타: 64. SVG Converter 스토어 앱 개인정보 보호 정책 안내
11178정성태4/10/201718577개발 환경 구성: 311. COM+ 관리자의 DCOM 구성에 나오는 기준
11177정성태4/7/201719103.NET Framework: 653. C# 7 새로운 문법(1) - 더욱 편리해진 Out 변수 사용파일 다운로드1
11176정성태4/5/201716074VC++: 117. Visual Studio - ATL COM 개체를 단위 테스트 하는 방법
11175정성태4/5/201725790.NET Framework: 652. C# 개발자를 위한 C++ COM 객체의 기본 구현 방식 설명파일 다운로드1
11174정성태4/3/201719335VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201722952VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
... 106  107  108  [109]  110  111  112  113  114  115  116  117  118  119  120  ...