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

비밀번호

댓글 작성자
 




... 121  122  123  [124]  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10822정성태7/7/201527265오류 유형: 299. The 'Visual C++ Project System Package' package did not load correctly.
10821정성태7/7/201519525오류 유형: 298. Unable to start debugging on the web server. IIS does not list a web site that matches the launched URL.
10820정성태7/7/201525469오류 유형: 297. HTTP Error 503. The service is unavailable. - 두 번째
10819정성태7/2/201528926오류 유형: 296. SQL Server Express 시작 오류 - error code 3417
10818정성태7/1/201527737오류 유형: 295. HTTP Error 503. The service is unavailable. [1]
10817정성태6/29/201531437.NET Framework: 523. C# 람다(Lambda)에서 변수 캡처 방식 [3]
10816정성태6/25/201527779.NET Framework: 522. 닷넷의 어셈블리 서명 데이터 확인 방법파일 다운로드1
10815정성태6/23/201525612Graphics: 1. 자네 나와 함께... UNITY 하지 않겠는가! [4]
10814정성태6/22/201523372.NET Framework: 521. Roslyn을 이용해 C# 문법 변형하기 (2) [5]
10813정성태6/21/201525166.NET Framework: 520. Roslyn을 이용해 C# 문법 변형하기 (1)
10812정성태6/20/201526302.NET Framework: 519. C# 6.0 오픈 소스 컴파일러 Roslyn - 빌드 및 테스트 방법 [1]
10811정성태6/20/201523166오류 유형: 294. OpenAuth 사용 시 System.Data.SqlClient.SqlException 예외가 Output 창에 출력되는 문제
10810정성태6/18/201522147개발 환경 구성: 270. Visual Studio에서 github 오픈 소스를 fork해서 테스트하는 방법 [1]
10809정성태6/18/201520044.NET Framework: 518. AllowPartiallyTrustedCallers 특성이 적용된 GAC 어셈블리에서 DynamicMethod의 calli 명령어 사용파일 다운로드1
10808정성태6/17/201522440.NET Framework: 517. calli IL 호출이 DllImport 호출보다 빠를까요? [1]파일 다운로드1
10807정성태6/16/201523514.NET Framework: 516. Microsoft.AspNet.Membership.OpenAuth 사용 시 "Local Database Runtime error occurred" 오류
10806정성태6/16/201541392.NET Framework: 515. OpenAuth.VerifyAuthentication 호출 시 The remote server returned an error: (400) Bad Request
10805정성태6/15/201522673Java: 17. 자바의 재미있는 상수 처리 방식
10804정성태6/10/201522344.NET Framework: 514. .NET CLR2 보안 모델에서의 APTCA 역할 (2)파일 다운로드1
10803정성태6/2/201524268.NET Framework: 513. UWP(Universal Windows Platform) 응용 프로그램의 새로운 라이브러리 버전 관리 해법 [2]
10802정성태6/2/201524365개발 환경 구성: 269. 마이크로소프트 온라인 강좌 소개 - Azure VPN 구성 방법 [1]
10801정성태5/31/201528914.NET Framework: 512. async/await 사용 시 hang 문제가 발생하는 경우 - 두 번째 이야기 [3]
10800정성태5/29/201524361개발 환경 구성: 268. 소개 - 프로세싱(https://processing.org/)
10799정성태5/29/201522142사물인터넷: 3. 책 소개 - 라즈베리 파이로 구현하는 사물 인터넷 프로젝트 [1]
10798정성태5/26/201521862기타: 53. 2015년 6월 10일 밤 10시 온라인 세미나 - 새로운 Windows 10 App을 개발하는 방법
10797정성태5/23/201521541VC++: 91. 자식 스레드에 자동 상속되는 TEB의 SubProcessTag 필드파일 다운로드1
... 121  122  123  [124]  125  126  127  128  129  130  131  132  133  134  135  ...