Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

닷넷 EXE 실행 오류 - Mixed mode assembly is build against version 'v2.0.50727' of the runtime

이상하군요, 동일한 실행 파일이 동일한 운영체제에서 고객사의 특정 컴퓨터에서만 다음과 같은 오류가 발생합니다.

Unhandled Exception: System.IO.FileLoadException: Mixed mode assembly is built against version 'v2.0.50727' of the runtime and cannot be loaded in the 4.0 runtime without additional configuration information.


순수하게 오류 메시지의 의미만으로 보면 .NET 2.0 ~ 3.5 대상으로 빌드한 "mixed mode 어셈블리"는 .NET 4.0 환경에서 별도의 옵션 설정 없이는 로드할 수 없다는 것입니다.

사실, 제가 만든 어셈블리는 .NET 2.0을 대상으로 빌드한 것이 맞습니다. 그리고 .NET 4.0 환경에서도 실행이 될 수 있도록 supportedRuntime 설정을 해둔 것인데요,

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup>
        <supportedRuntime version="v4.0.30319"/>
        <supportedRuntime version="v2.0.50727"/>
    </startup>
</configuration>

메시지에 따라 이 오류를 해결하려면 "additional configuration information"이 필요하고, 여기서의 요구 사항을 만족하는 설정은 useLegacyV2RuntimeActivationPolicy입니다.

useLegacyV2RuntimeActivationPolicy
; https://docs.microsoft.com/en-us/dotnet/framework/configure-apps/file-schema/startup/startup-element

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup useLegacyV2RuntimeActivationPolicy="true">
        <supportedRuntime version="v4.0.30319"/>
        <supportedRuntime version="v2.0.50727"/>
    </startup>
</configuration>

일단, 이것으로 급한 불은 껐는데요. ^^




문제는, "mixed mode assembly"의 기준입니다. 아래의 문서에 보면 이에 대해 설명하고 있는데요,

Mixed (native and managed) assemblies
; https://docs.microsoft.com/en-us/cpp/dotnet/mixed-native-and-managed-assemblies

Mixed assemblies are capable of containing both unmanaged machine instructions and MSIL instructions.
...[생략]...
Visual C++ only supports the generation of mixed managed assemblies by using the /clr compiler option.

(14) What is a mixed-mode assembly?
; http://stackoverflow.com/questions/7266936

A mixed-mode assembly is a dynamic link library that contains both managed code and native code for a particular processor architecture. Since it contains native code it can only be loaded into a process that matches the processor architecture it was compiled for.


보는 바와 같이, 현재 mixed managed assembly를 생성할 수 있는 유일한 방법은 Visual C++/CLI만 가능한 것입니다. 반면, 제가 겪은 문제의 어셈블리는 C#으로 AnyCPU를 대상으로 만든 것이기 때문에 저 기준에 부합하지 않습니다.

그렇기 때문에, 대부분의 환경에서는 정상적으로 실행이 되었지만 "원인을 알 수 없는" 그 고객사의 특정 컴퓨터에서만 저 오류가 발생하고 있는 것입니다. 그나마 원인을 유추해 볼 수 있는 것은 해당 어셈블리가 unsafe 예약어를 사용해 포인터를 다루는 코드가 있긴 하다는 점입니다. 따라서 일단 해당 어셈블리의 unsafe 코드 사용을 없애고 다시 빌드했지만, 고객사 측의 실 서버에서 진행된 문제라 다시 테스트를 할 수는 없는 상황입니다. (나중에 혹시나, 해당 고객사로부터 피드백을 받으면 기록에 추가하겠습니다. ^^)




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







[최초 등록일: ]
[최종 수정일: 4/22/2021]

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

비밀번호

댓글 작성자
 




... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13153정성태11/2/20227036.NET Framework: 2062. C# - 코드로 재현하는 소켓 상태(SYN_SENT, SYN_RECV)
13152정성태11/1/20225654.NET Framework: 2061. ASP.NET Core - DI로 추가한 클래스의 초기화 방법 [1]
13151정성태10/31/20225762C/C++: 161. Windows 11 환경에서 raw socket 테스트하는 방법파일 다운로드1
13150정성태10/30/20225816C/C++: 160. Visual Studio 2022로 빌드한 C++ 프로그램을 위한 다른 PC에서 실행하는 방법
13149정성태10/27/20225723오류 유형: 825. C# - CLR ETW 이벤트 수신이 GCHeapStats_V1/V2에 대해 안 되는 문제파일 다운로드1
13148정성태10/26/20225738오류 유형: 824. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFramew
13147정성태10/25/20224838오류 유형: 823. Visual Studio 2022 - Unable to attach to CoreCLR. The debugger's protocol is incompatible with the debuggee.
13146정성태10/24/20225676.NET Framework: 2060. C# - Java의 Xmx와 유사한 힙 메모리 최댓값 제어 옵션 HeapHardLimit
13145정성태10/21/20225952오류 유형: 822. db2 - Password validation for user db2inst1 failed with rc = -2146500508
13144정성태10/20/20225789.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법파일 다운로드1
13143정성태10/19/20226323오류 유형: 821. windbg/sos - Error code - 0x000021BE
13142정성태10/18/20225137도서: 시작하세요! C# 12 프로그래밍
13141정성태10/17/20226804.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13140정성태10/11/20226159C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/20225990.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/20227296.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/20225653.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/20226236.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/20226470.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기
13134정성태10/4/20225215오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
13133정성태10/4/20225530Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]
13132정성태10/3/20225427스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현
13131정성태10/3/20228134.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/20225181.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/20225470.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
13128정성태9/23/20228066C/C++: 158. Visual C++ - IDL 구문 중 "unsigned long"을 인식하지 못하는 #import파일 다운로드1
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...