Почему я получаю System.IO.FileLoadException: не удается загрузить файл или сборку, примерно раз в неделю, на моем веб-сайте ASP.Net?
У меня есть довольно простой внутренний веб-сайт ASP.Net, в котором возникают проблемы с загрузкой dll Microsoft.Practices.EnterpriseLibrary.Data примерно раз в неделю. Вот сообщение об исключении:
System.IO.FileLoadException: Could not load file or assembly 'Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. Access is denied.
File name: 'Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null'
at foobar.Intranet.Logic.Data.UserDB.SelectByUserName(String userName)
at foobar.Intranet.Logic.Info.User.ValidateUser(String userName) in F:\Development\foobar\foobar\foobar.Intranet.Logic\Info\User.cs:line 130
at Login.ValidateUser(String username, String password) in e:\foobar\foobar.Intranet\Login.aspx.cs:line 32
=== Pre-bind state information ===
LOG: User = Unknown
LOG: DisplayName = Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null
(Fully-specified)
LOG: Appbase = file:///E:/foobar/foobar.Intranet/
LOG: Initial PrivatePath = E:\foobar\foobar.Intranet\bin Calling assembly : foobar.Intranet.Logic, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: E:\foobar\foobar.Intranet\web.config
LOG: Using host configuration file: \\?\C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet.config
LOG: Using machine configuration file from C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\config\machine.config.
LOG: Policy not being applied to reference at this time (private, custom, partial, or location-based assembly bind).
LOG: Attempting download of new URL file:///C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/Temporary ASP.NET Files/foobar.intranet/668896d8/82d7e51c/Microsoft.Practices.EnterpriseLibrary.Data.DLL.
LOG: Attempting download of new URL file:///C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/Temporary ASP.NET Files/foobar.intranet/668896d8/82d7e51c/Microsoft.Practices.EnterpriseLibrary.Data/Microsoft.Practices.EnterpriseLibrary.Data.DLL.
LOG: Attempting download of new URL file:///E:/foobar/foobar.Intranet/bin/Microsoft.Practices.EnterpriseLibrary.Data.DLL.
ERR: Failed to complete setup of assembly (hr = 0x80070005). Probing terminated.
Вещи примечания:
- Простой сброс IIS устраняет проблему.
- У нас один и тот же код работал на одном веб-сервере без проблем. Затем мы переместили сайт на два новых веб-сервера с балансировкой нагрузки (с использованием липких сессий) (все три Windows Server 2003 R2 Standard Edition SP1). Теперь каждый из веб-серверов с балансировкой нагрузки выбрасывает это исключение один раз в неделю на ровном месте.
- Единственное существенное отличие, о котором я могу подумать, это то, что я установил 4.0.NET Framework на серверах с балансировкой нагрузки. Сайт по-прежнему работает под ASP.NET 2.0, поэтому я не понимаю, как это может быть проблемой
- Я настроил службу индексирования так, чтобы она не выполняла поиск в папке "Temporary ASP.NET Files", но это не помогло.
- Мы используем Microsoft.Practices.EnterpriseLibrary.Data dll везде на нашем сайте. Почти каждая страница использует нашу логическую библиотеку DLL, которая в свою очередь использует библиотеку EnterpriseLibrary.
- Хотя ошибки возникали однажды, я даже посмотрел, какие процессы блокировали dll в папке "Temporary ASP.NET Files", и это ничем не отличалось от блокировок на сервере, который работал нормально.
- Как только ошибка начинается, она выдает ошибку каждый раз, пока не будет выполнен iisreset
Любая идея, которую кто-либо может предложить, будет высоко ценится. Дайте мне знать, если я что-то пропустил.
Спасибо!
2 ответа
Посмотрите на Сборку журнала привязок сборки. Это может указать вам правильное направление.
Я быстро взглянул на другие ответы SO, и один человек предположил, что приложение, возможно, было разработано для подписанной версии DLL, но рабочая среда имеет доступ только к неподписанной версии. Похоже, ваше производство загружает неподписанную сборку (PublicKeyToken=null
).
Установите следующие пакеты nuget:
Пакет установки log4net -Version 2.0.0 Пакет установки linqtoexcel
Install-Package System.Data.Sqlite.x86 -Version 1.0.88.0 Install-Package ServiceStack -Version 3.9.71 Install-Package ServiceStack.OrmLite.Sqlite32 -Version 3.9.71