MySqlConnector 사용 시 System.IO.FileLoadException 오류
.NET Framework 환경에서 MySqlConnector의 MySqlConnection.Open 메서드 실행 시 이런 오류가 발생할 수 있습니다.
System.IO.FileLoadException
HResult=0x80131040
Message=Could not load file or assembly 'System.Diagnostics.DiagnosticSource, Version=6.0.0.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)
Source=MySqlConnector
StackTrace:
at MySqlConnector.MySqlConnection.<OpenAsync>d__26.MoveNext()
at System.Runtime.CompilerServices.AsyncTaskMethodBuilder.Start[TStateMachine](TStateMachine& stateMachine)
at MySqlConnector.MySqlConnection.OpenAsync(Nullable`1 ioBehavior, CancellationToken cancellationToken)
at MySqlConnector.MySqlConnection.Open()
물론, 진짜로 System.Diagnostics.DiagnosticSource 어셈블리가 참조돼 있지 않다면 새롭게 설치하면 되는데요,
Install-Package System.Diagnostics.DiagnosticSource -Version 6.0.0.0
기존에 이미 6.0.0.0보다 높은 버전으로 해당 어셈블리가 참조돼 있어도 저 오류가 발생할 것입니다. 그런 경우, 프로젝트 빌드 시 경고를 자세히 보면 이런 식의 메시지가 보일 텐데,
1> Consider app.config remapping of assembly "System.Diagnostics.DiagnosticSource, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51" from Version "6.0.0.0" [] to Version "7.0.0.2" [C:\temp\WebSamples\packages\System.Diagnostics.DiagnosticSource.7.0.2\lib\net462\System.Diagnostics.DiagnosticSource.dll] to solve conflict and get rid of warning.
전에도 이야기했지만,
Consider app.config remapping of assembly "..." from Version "..." [...] to Version "..." [...] to solve conflict and get rid of warning.
; https://www.sysnet.pe.kr/2/0/12027
이런 경우 AutoGenerateBindingRedirects 옵션을 True로 주거나, 아니면 app.config/Web.config 등에 assemblyBinding으로 이렇게 추가시켜 주면 됩니다.
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<!-- ...[생략]... -->
<dependentAssembly>
<assemblyIdentity name="System.Diagnostics.DiagnosticSource" publicKeyToken="cc7b13ffcd2ddd51"/>
<bindingRedirect oldVersion="0.0.0.0-7.0.0.2" newVersion="7.0.0.2"/>
</dependentAssembly>
<!-- ...[생략]... -->
</assemblyBinding>
</runtime>
참고로, 위와 같은 바인딩 정책에 대해서는 이미 아래의 글에서 자세하게 설명한 적이 있고,
.NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션
; https://www.sysnet.pe.kr/2/0/12210
.NET Core/5+가 대세가 된 요즘에는 발생하지 않을 문제이니 가볍게 알고만 지나가도 될 문제입니다. ^^
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]