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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  103  104  [105]  ...
NoWriterDateCnt.TitleFile(s)
11299정성태9/9/201719652개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
11298정성태9/8/201722920VC++: 119. EnumProcesses / EnumProcessModules API 사용 시 주의점 [1]
11297정성태9/8/201719588디버깅 기술: 96. windbg - 풀 덤프에 포함된 모든 닷넷 모듈을 파일로 저장하는 방법
11296정성태9/8/201722786웹: 36. Edge - "이 웹 사이트는 이전 기술에서 실행되며 Internet Explorer에서만 작동합니다." 끄는 방법
11295정성태9/7/201720172디버깅 기술: 95. Windbg - .foreach 사용법
11294정성태9/4/201719965개발 환경 구성: 329. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 [1]
11293정성태9/4/201720465개발 환경 구성: 328. Visual Studio(devenv.exe)를 배치 파일(.bat)을 통해 실행하는 방법
11292정성태9/4/201718740오류 유형: 419. Cannot connect to WMI provider - Invalid class [0x80041010]
11291정성태9/3/201720618개발 환경 구성: 327. 아파치 서버 2.4를 위한 mod_aspdotnet 마이그레이션
11290정성태9/3/201723827개발 환경 구성: 326. 아파치 서버에서 ASP.NET을 실행하는 mod_aspdotnet 모듈 [2]
11289정성태9/3/201721451개발 환경 구성: 325. GAC에 어셈블리 등록을 위해 gacutil.exe을 사용하는 경우 주의 사항
11288정성태9/3/201718230개발 환경 구성: 324. 윈도우용 XAMPP의 아파치 서버 구성 방법
11287정성태9/1/201727450.NET Framework: 680. C# - 작업자(Worker) 스레드와 UI 스레드 [11]
11286정성태8/28/201714794기타: 67. App Privacy Policy
11285정성태8/28/201723374.NET Framework: 679. C# - 개인 키 보안의 SFTP를 이용한 파일 업로드파일 다운로드1
11284정성태8/27/201721387.NET Framework: 678. 데스크톱 윈도우 응용 프로그램에서 UWP 라이브러리를 이용한 비디오 장치 열람하는 방법 [1]파일 다운로드1
11283정성태8/27/201717173오류 유형: 418. CSS3117: @font-face failed cross-origin request. Resource access is restricted.
11282정성태8/26/201719614Math: 22. 행렬로 바라보는 피보나치 수열
11281정성태8/26/201721448.NET Framework: 677. Visual Studio 2017 - NuGet 패키지를 직접 참조하는 PackageReference 지원 [2]
11280정성태8/24/201718449디버깅 기술: 94. windbg - 풀 덤프에 포함된 모든 모듈을 파일로 저장하는 방법
11279정성태8/23/201730099.NET Framework: 676. C# Thread가 Running 상태인지 아는 방법
11278정성태8/23/201718251오류 유형: 417. TFS - Warning - Unable to refresh ... because you have a pending edit. [1]
11277정성태8/23/201719474오류 유형: 416. msbuild - error MSB4062: The "TransformXml" task could not be loaded from the assembly
11276정성태8/23/201723783.NET Framework: 675. C# - (파일) 확장자와 연결된 실행 파일 경로 찾기 [2]파일 다운로드1
11275정성태8/23/201732761개발 환경 구성: 323. Visual Studio 설치 없이 빌드 환경 구성 - Visual Studio 2017용 Build Tools [1]
11274정성태8/22/201719330.NET Framework: 674. Thread 타입의 Suspend/Resume/Join 사용 관련 예외 처리
... 91  92  93  94  95  96  97  98  99  100  101  102  103  104  [105]  ...