Microsoft MVP성태의 닷넷 이야기
.NET Framework: 1061. 서버 유형의 COM+에 적용할 수 없는 Server GC [링크 복사], [링크+제목 복사],
조회: 19758
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

서버 유형의 COM+에 적용할 수 없는 Server GC

다음의 문서에 나오듯이,

Using Per-Application Configuration Files
; https://docs.microsoft.com/en-us/windows/win32/cossdk/using-per-application-configuration-files

서버 유형의 COM+ 응용 프로그램에 app.config을 적용하려면 다음의 2개 파일을 생성한 다음,

[application.manifest 파일]

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0" />

[application.config 파일]

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <appSettings>
        <add key="myValue" value="TEST"/>
    </appSettings>
</configuration>

COM+ 응용 프로그램 속성 창의 "Activation(활성화)" 탭에서 "Application Root Directory(응용 프로그램 루트 디렉터리)"를 설정하는 것으로 가능합니다.

complus_app_config_1.png

그런데 여기서 재미있는 것은, app.config의 모든 설정이 dllhost.exe 프로세스에 적용되지는 않는다는 점입니다. 그 한 사례로, ServerGC 유형에 대한 설정인데요,

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <appSettings>
        <add key="myValue" value="TEST" />
    </appSettings>
    <runtime>
        <gcServer enabled="true"/>
    </runtime>
</configuration>

위와 같이 설정하고 COM+의 Activate 메서드에서 다음과 같이 확인해 보면,

[JustInTimeActivation(true)]
// ...[생략]...
public class TestComplus : ServicedComponent
{
    public TestComplus()
    {
    }

    protected override void Activate()
    {
        string text = System.Configuration.ConfigurationSettings.AppSettings["myValue"];
        Environment.SetEnvironmentVariable("TEST_ENV1", text);
        Environment.SetEnvironmentVariable("TEST_ENV2", GCSettings.IsServerGC.ToString());
    }

    // ...[생략]...
}

dllhost.exe 환경 변수의 TEST_ENV1에는 "TEST" 문자열이 있지만, TEST_ENV2에는 "False" 값이 있는 것을 볼 수 있습니다. 실제로, GC가 발생했을 때의 호출 스택을 보면 "WKS" 문자열을 통해 이를 짐작할 수 있습니다.

clr!WKS::gc_heap::mark_phase+197 
clr!WKS::gc_heap::gc1+a3 
clr!WKS::gc_heap::garbage_collect+54c 
clr!WKS::GCHeap::GarbageCollectGeneration+10d 
clr!WKS::gc_heap::trigger_gc_for_alloc+2d 
clr!WKS::GCHeap::Alloc+2ab 
...[생략]...

의도한대로 ServerGC가 사용이 되었다면 "SVR"이 나와야 합니다.

clr!SVR::gc_heap::plan_phase+12bb
clr!SVR::gc_heap::gc1+c3
clr!SVR::gc_heap::garbage_collect+f0
clr!SVR::gc_heap::gc_thread_function+74
clr!SVR::gc_heap::gc_thread_stub+9a
clr!&lt;lambda_5d4b8dc0ce3eb05b864e38505727a1c1&gt;::&lt;lambda_invoker_cdecl&gt;+51
kernel32!BaseThreadInitThunk+14
ntdll!RtlUserThreadStart+21




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







[최초 등록일: ]
[최종 수정일: 6/1/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
14006정성태8/23/2025217Linux: 121. Linux - snap 패키지 관리자로 설치한 소프트웨어의 디렉터리 접근 제한
14005정성태8/21/2025480오류 유형: 982. sudo: unable to load /usr/libexec/sudo/sudoers.so: libssl.so.3: cannot open shared object file: No such file or directory
14004정성태8/21/2025566오류 유형: 981. dotnet 실행 시 No usable version of the libssl was found
14003정성태8/21/2025619닷넷: 2357. C# 14 - (9) 새로운 지시자 추가 (Ignored directives)
14002정성태8/20/20251154오류 유형: 980. C# - appsettings.json 파일의 설정값이 적용 안 된다면?
14001정성태8/19/20251360닷넷: 2356. .NET SDK 10 - 단일 소스 코드 파일을 빌드/실행하는 기능을 "dotnet" 명령어에 추가
14000정성태8/18/20251184오류 유형: 979. ERROR: failed to solve: failed to read dockerfile: open Dockerfile: no such file or directory
13999정성태8/15/20251455닷넷: 2355. C# 14 - (8) null 조건부 연산자 개선 - 대입문에도 사용 가능파일 다운로드1
13998정성태8/14/20251322닷넷: 2354. C# 14 - (7) 확장 메서드에 정적 메서드와 속성 지원을 위한 전용 구문 추가파일 다운로드1
13997정성태8/14/20251426Linux: 120. docker 컨테이너로 매핑된 볼륨에 컨테이너 측의 사용자 ID를 유지하면서 복사하는 방법
13996정성태8/13/2025989오류 유형: 978. Unable to find the requested .Net Framework Data Provider.
13995정성태8/13/2025986개발 환경 구성: 754. Visual C++ - 리눅스 빌드를 위한 Ubuntu 18 docker 컨테이너 설정
13994정성태8/12/2025949오류 유형: 977. SQL Server - User, group, or role '...' already exists in the current database. (Microsoft SQL Server, Error: 15023)
13993정성태8/11/20251496오류 유형: 976. Microsoft.ML.OnnxRuntimeGenAI 패키지 사용 시 "cublasLt64_12.dll" which is missing. (Error 126: "The specified module could not be found.") 오류
13992정성태8/11/20251639닷넷: 2353. C# - Foundry Local을 이용한 gpt-oss-20b 모델 사용파일 다운로드1
13991정성태8/9/20251460오류 유형: 975. winget - Foundry Local 패키지 업데이트가 안 되는 문제
13990정성태8/8/20251113Windows: 283. Time zone 설정이 없는 Windows Server 2025
13989정성태8/8/20251604닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
13988정성태8/8/20251722오류 유형: 974. 비주얼 스튜디오 업데이트 시 잠김 파일 경고 - Visual Studio Standard Collector Service 150 (VSStandardCollectorService150)
13987정성태8/7/20251376닷넷: 2351. C# 14 - (6) event와 생성자에도 partial 메서드 적용파일 다운로드1
13986정성태8/6/20251396닷넷: 2350. C# 14 - (5) 람다 매개 변수에 접근자가 있는 경우에도 타입 생략 가능파일 다운로드1
13985정성태8/6/20251938오류 유형: 973. "wsl --install" 명령어 수행 시 "The server name or address could not be resolved"
13984정성태8/6/20251648Windows: 282. 윈도우 운영체제에 추가된 ssh 서버(Win32-OpenSSH)
13983정성태8/4/20251904오류 유형: 972. Microsoft.Data.SqlClient 6.1.0 버전부터 .NET 8 이상만 지원
13982정성태8/2/20252084개발 환경 구성: 753. CentOS 7 컨테이너 내에서 openssh 서버 호스팅
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...