Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 4개 있습니다.)
.NET Framework: 975. .NET Core를 직접 호스팅해 (runtimeconfig.json 없이) EXE만 배포해 실행
; https://www.sysnet.pe.kr/2/0/12427

.NET Framework: 992. C# - .NET Core 3.0 이상부터 제공하는 runtimeOptions의 rollForward 옵션
; https://www.sysnet.pe.kr/2/0/12471

.NET Framework: 1165. .NET Core/5+ 빌드 시 runtimeconfig.json에 설정을 반영하는 방법
; https://www.sysnet.pe.kr/2/0/12983

.NET Framework: 2096. .NET Core/5+ - PublishSingleFile 유형에 대한 runtimeconfig.json 설정
; https://www.sysnet.pe.kr/2/0/13265




.NET Core/5+ - PublishSingleFile 유형에 대한 runtimeconfig.json 설정

예제를 먼저 들어볼까요? ^^

다음과 같이 간단하게 코딩을 하고,

// .NET 7 + Console App

foreach (var item in GC.GetConfigurationVariables())
{
    Console.WriteLine(item);
}

/*
Hello, World!
[ServerGC, False]
[ConcurrentGC, True]
[RetainVM, False]
[NoAffinitize, False]
[GCCpuGroup, False]
[GCLargePages, False]
[HeapCount, 1]
[GCHeapAffinitizeMask, 0]
[GCHeapAffinitizeRanges, ]
[GCHighMemPercent, 0]
[GCHeapHardLimit, 0]
[GCHeapHardLimitPercent, 0]
[GCHeapHardLimitSOH, 0]
[GCHeapHardLimitLOH, 0]
[GCHeapHardLimitPOH, 0]
[GCHeapHardLimitSOHPercent, 0]
[GCHeapHardLimitLOHPercent, 0]
[GCHeapHardLimitPOHPercent, 0]
[GCConserveMem, 0]
*/

실행 결과를 보면, 기본 상태인 경우 ConcurrentGC는 True인 것을 볼 수 있습니다. 이 상태에서, 만약 출력 디렉터리에 "ConsoleApp1.runtimeconfig.json" 파일을 만들어 다음과 같이 설정해 주면,

{
  "runtimeOptions": {
    "tfm": "net7.0",
    "framework": {
      "name": "Microsoft.NETCore.App",
      "version": "7.0.0"
    },
    "configProperties": {
      "System.GC.Concurrent": False
    }
  }
}

이후 ConsoleApp1 실행 시 화면에는 Concurrent 옵션이 False로 나옵니다.




그런데, 위의 응용 프로그램을 PublishSingleFile 옵션을 적용해,

C# - PublishSingleFile과 관련된 옵션
; https://www.sysnet.pe.kr/2/0/13159

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>
        <TargetFramework>net7.0</TargetFramework>
        <ImplicitUsings>enable</ImplicitUsings>
        <Nullable>enable</Nullable>

        <PublishSingleFile>true</PublishSingleFile>
        <RuntimeIdentifier>win-x64</RuntimeIdentifier>
        <DebugType>embedded</DebugType>
    </PropertyGroup>

</Project>

배포하는 경우라면 어떻게 될까요? 배포 디렉터리를 보면, ConsoleApp1.exe 파일이 생성되는데요, 이 상태에서 실행하면 (예상할 수 있듯이) Concurrent 옵션이 True로 나옵니다. 그런데 이전과 마찬가지로 이 옵션을 변경하기 위해 ConsoleApp1.runtimeconfig.json을 만들어 주면 어떻게 될까요?

실행해 보면, ConsoleApp1.runtimeconfig.json 설정이 전혀 통하지 않는 것을 볼 수 있습니다. 왜냐하면, (.NET 7 이후의 경우) exe에 포함된 바이너리들은 모두 메모리 매핑에서 로딩이 돼 현재 경로가 사실상 메모리가 되기 때문에 exe가 출력된 디렉터리를 더 이상 참조하지 않기 때문입니다.

따라서 PublishSingleFile의 경우 저런 옵션을 변경하고 싶다면 단일 이미지 파일 생성 이전에, 즉 프로젝트 단계에서 runtimeconfig.template.json을 추가해야 합니다.

{
    "configProperties": {
        "System.GC.Concurrent": false,
    }
}

혹은 같은 옵션이 csproj 프로젝트 파일에도 있다면 그걸 설정할 수 있는데요,

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        ...[생략]...

        <ConcurrentGarbageCollection>false</ConcurrentGarbageCollection>
    </PropertyGroup>

</Project>

만약 런타임에 꼭 변경해야 할 필요가 있다면, 그때는 환경 변수를 이용하는 수밖에는 없습니다. 따라서 위와 같은 경우에는 아래와 같이 설정을 한 다음,

c:\temp> SET DOTNET_gcConcurrent=0

PublishSingleFile 옵션으로 배포한 파일을 실행해야 합니다.

정리해 보면, 런타임 옵션은 1) csproj로 설정하거나, 2) runtimeconfig.json으로 설정하거나, 3) 환경 변수로 설정하는 것이 가능하지만, 경우에 따라서는 꼭 3번 방법으로만 바꿀 수 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/18/2023]

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)
1805정성태11/5/201421948.NET Framework: 476. Visual Studio에서 Mono용 Profiler 개발 [3]파일 다운로드1
1804정성태11/5/201428166.NET Framework: 475. ETW(Event Tracing for Windows)를 C#에서 사용하는 방법 [9]파일 다운로드1
1803정성태11/4/201420283오류 유형: 261. Windows Server Backup 오류 - Error in backup of E:\$Extend\$RmMetadata\$TxfLog
1802정성태11/4/201422228오류 유형: 260. 이벤트 로그 - Windows Error Reporting / AEAPPINVW8
1801정성태11/4/201427561오류 유형: 259. 이벤트 로그 - Windows Error Reporting / IPX Assertion / KorIME.exe [1]
1800정성태11/4/201418234오류 유형: 258. 이벤트 로그 - Starting a SMART disk polling operation in Automatic mode.
1799정성태11/4/201423058오류 유형: 257. 이벤트 로그 - The WMI Performance Adapter service entered the stopped state.
1798정성태11/4/201431831오류 유형: 256. 이벤트 로그 - The WinHTTP Web Proxy Auto-Discovery Service service entered the stopped state. [1]
1797정성태11/4/201417482오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
1796정성태10/30/201424511개발 환경 구성: 249. Visual Studio 2013에서 Mono 컴파일하는 방법
1795정성태10/29/201427001개발 환경 구성: 248. Lync 2013 서버 설치 방법
1794정성태10/29/201422492개발 환경 구성: 247. "Microsoft Office 365 Enterprise E3" 서비스에 대한 간략 소개
1793정성태10/27/201423105.NET Framework: 474. C# - chromiumembedded 사용 - 두 번째 이야기 [2]파일 다운로드1
1792정성태10/27/201423277.NET Framework: 473. WebClient 객체에 쿠키(Cookie)를 사용하는 방법
1791정성태10/22/201422997VC++: 83. G++ - 템플릿 클래스의 iterator 코드 사용에서 발생하는 컴파일 오류 [5]
1790정성태10/22/201418531오류 유형: 254. NETLOGON Service is paused on [... AD Server...]
1789정성태10/22/201421192오류 유형: 253. 이벤트 로그 - The client-side extension could not remove user policy settings for '...'
1788정성태10/22/201423226VC++: 82. COM 프로그래밍에서 HRESULT 타입의 S_FALSE는 실패일까요? 성공일까요? [2]
1787정성태10/22/201431398오류 유형: 252. COM 개체 등록시 0x8002801C 오류가 발생한다면?
1786정성태10/22/201432678디버깅 기술: 65. 프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법 [3]파일 다운로드1
1785정성태10/22/201421938오류 유형: 251. 이벤트 로그 - Load control template file /_controltemplates/TaxonomyPicker.ascx failed [1]
1784정성태10/22/201430023.NET Framework: 472. C/C++과 C# 사이의 메모리 할당/해제 방법파일 다운로드1
1783정성태10/21/201423429VC++: 81. 프로그래밍에서 borrowing의 개념
1782정성태10/21/201420191오류 유형: 250. 이벤트 로그 - Application Server job failed for service instance Microsoft.Office.Server.Search.Administration.SearchServiceInstance
1781정성태10/21/201420598디버깅 기술: 64. new/delete의 짝이 맞는 경우에도 메모리 누수가 발생한다면?
1780정성태10/15/201424256오류 유형: 249. The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
... 121  122  123  124  125  126  127  128  129  [130]  131  132  133  134  135  ...