我不确定我的ELMAH设置发生了什么,它工作正常,然后停止工作。我使用ELMAH核心和ELMAH MVC。
即使检查我的源代码控制,webconfig中也没有真正改变。我还注意到在实际的ELMAH错误日志数据库中,记录从大约11/5开始就停止了记录。无法在源代码管理中找到任何代码更改以与此一致。
我有两个问题,一个是去myapp/elmah
我收到了错误:
System.Data.SqlClient.SqlException:找不到存储过程'ELMAH_GetErrorsXml'
并且web.config似乎已正确配置为指向该数据库(将在下面发布完整部分)。
第二个问题是当我将应用程序部署到生产环境时,电子邮件通知(可能是日志记录本身)不起作用。在localhost上正常工作。我收到了电子邮件,但在部署到生产时,没有。
以下是web.config的部分:
<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>
<elmah>
<security allowRemoteAccess="yes"/>
<errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="ElmahDb" />
<errorMail from="no-reply@mysite" to="myself@mysite" subject="Mysite Error" smtpPort="0" async="false" />
</elmah>
<connectionStrings>
<add name="ElmahDb" connectionString="Data Source=mydb;Initial Catalog=ErrorLog;Persist Security Info=True;User ID=id;Password=password" 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="false" />
<add key="elmah.mvc.allowedRoles" value="*" />
<add key="elmah.mvc.route" value="elmah" />
</appSettings>
<system.web>
<httpModules>
<add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
<add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
</httpModules>
</system.web>
<system.net>
<mailSettings>
<smtp deliveryMethod="Network">
<network defaultCredentials="true" host="mySMTP" port="25" />
</smtp>
</mailSettings>
</system.net>
<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>
</system.webServer>
就是这样,我见过的唯一另一件事就是注释掉默认的HandleErrorAttribute,但那些似乎是来自旧文章而且ELMAH MVC无论如何都不再需要它,无论我是否尝试过离开它和评论它出来了:
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
filters.Add(new HandleErrorAttribute());
}
它的功能仍然相同。我也尝试为ELMAH启用/禁用remoteAccess,但这也没有做任何事情。在localhost和production上,我在尝试访问/elmah
时遇到同样的错误。电子邮件只发送到localhost。那么我的配置有什么问题?为什么我会收到这些错误?