Прежде всего, вот несколько потенциальных дубликатов, которые не помогли:
Не удается получить доступ / elmah на рабочем сервере с Elmah MVC?
ELMAH не делает 't вставлять журналы ошибок в базу данных SQL при работе
ELMAH работает на локальном компьютере, но не при работе
Elmah, преобразовать в .Net4 vs2010, запустить на сервере 2008,не работает
Невозможно открыть «тест» базы данных, запрошенный при входе в систему.Ошибка входаОшибка входа для пользователя 'xyz \ ASPNET'
Ошибка "Ошибка входа для пользователя 'NT AUTHORITY \ IUSR'" в ASP.NET и SQL Server 2008
Мое приложение ASP.NET MVC использует одну базу данных SQL Server, а ELMAH - другую.На тестовом сервере учетная запись пула приложений IIS используется для подключения к SQL Server, как и предполагалось, и все работает нормально.Однако при переходе к производству с теми же настройками Entity Framework продолжает использовать учетную запись Windows IIS APPPOOL\Product
для подключения к SQL Server, но ELMAH начинает пытаться использовать учетную запись DOMAIN\MACHINENAME$
(которую я не создал / не настроил -Я не знаю достаточно о доменах Windows, чтобы знать, откуда это).
Попытка перейти на страницу ELMAH, на которой перечислены ошибки (т. Е. http://localhost/elmah
), возвращает HTTP 500, а в журнале событий отображается это классическое сообщение об ошибке:
Невозможно открыть базу данных «Ошибки»запрашивается логином.Ошибка входаНе удалось войти в систему для пользователя 'DOMAIN \ MACHINENAME $'
В отчаянии я попытался просто предоставить DOMAIN\MACHINENAME$
разрешения для базы данных (использовал SSMS для сопоставления имени входа с базой данных Errors
и выбрал db_datawriter
и db_datareader
), включая хранимые процедуры, предлагаемые здесь , но даже это не работает.Именно этот процесс я и сделал, чтобы настроить его на тестовом сервере.
Производство - Windows Server 2012 R2 с IIS 8.5.На данный момент Windows 10 работает под управлением IIS 10. Оба работают под управлением SQL Server 2016 Express v13.
Web.config со всем включенным, даже немного связанным с этим:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
<sectionGroup name="elmah">
<section name="security" requirePermission="false" type="Elmah.SecuritySectionHandler, Elmah" />
<section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah" />
<section name="errorMail" requirePermission="false" type="Elmah.ErrorMailSectionHandler, Elmah" />
<section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah" />
</sectionGroup>
</configSections>
<connectionStrings>
<clear />
<!-- Entity Framework connection, works fine on both servers -->
<add name="DbContext" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\Data.mdf;Initial Catalog=Data;Integrated Security=True" providerName="System.Data.SqlClient" />
<!-- ELMAH connection, only works on test server -->
<add name="ElmahLog" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\Errors.mdf;Initial Catalog=Errors;Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>
<appSettings>
<add key="elmah.mvc.disableHandler" value="false" />
<add key="elmah.mvc.disableHandleErrorFilter" value="false" />
<add key="elmah.mvc.requiresAuthentication" value="true" />
<add key="elmah.mvc.IgnoreDefaultRoute" value="true" />
<add key="elmah.mvc.allowedRoles" value="Developer" />
<add key="elmah.mvc.route" value="dev/elmah" />
<add key="elmah.mvc.UserAuthCaseSensitive" value="true" />
</appSettings>
<system.web>
<globalization culture="en-US" />
<authentication mode="Windows" />
<compilation debug="false" targetFramework="4.5.2">
<assemblies>
<add assembly="System.Core, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</assemblies>
</compilation>
<httpRuntime targetFramework="4.5.2" />
<httpModules>
<add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
<add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
</httpModules>
<customErrors mode="Off" />
</system.web>
<system.webServer>
<modules>
<add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" preCondition="managedHandler" />
<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" preCondition="managedHandler" />
<add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" preCondition="managedHandler" />
</modules>
<validation validateIntegratedModeConfiguration="false" />
</system.webServer>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
<elmah>
<security allowRemoteAccess="true" />
<errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="ElmahLog" />
</elmah>
<system.codedom>
<compilers>
<compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.8.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:6 /nowarn:1659;1699;1701" />
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.8.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:14 /nowarn:41008 /define:_MYTYPE=\"Web\" /optionInfer+" />
</compilers>
</system.codedom>
</configuration>
Почему ELMAH использует другую учетную запись и почему я не могу предоставить эту учетную записьразрешения?