0

我有一个使用 ASP.Net MVC 开发的网站,并使用 Log4net 进行异常记录。该网站运行良好,直到大约 4 小时前。在过去 2 周内,我们没有对网站进行任何更改。自从我们在大约 1 个月前建立网站以来,该网站一直运行顺利。该网站由我们的 ISP 托管在共享主机帐户上。

这是我们收到的例外情况:

[FormatException: String was not recognized as a valid Boolean.]
   log4net.Core.LoggerManager.RegisterAppDomainEvents() +0
   log4net.Core.LoggerManager..cctor() +33

[TypeInitializationException: The type initializer for 'log4net.Core.LoggerManager' threw an exception.]
   log4net.Core.LoggerManager.GetLogger(Assembly repositoryAssembly, String name) +0
   log4net.LogManager.GetLogger(Assembly repositoryAssembly, String name) +8
   log4net.LogManager.GetLogger(String name) +20
   i3t.LcaWeb.View.MvcApplication..cctor() in Global.asax.cs:17

[TypeInitializationException: The type initializer for 'i3t.LcaWeb.View.MvcApplication' threw an exception.]
   i3t.LcaWeb.View.MvcApplication..ctor() +0
   ASP.global_asax..ctor() in App_global.asax.fqjmwqjv.0.cs:0

[TargetInvocationException: Exception has been thrown by the target of an invocation.]
   System.RuntimeTypeHandle.CreateInstance(RuntimeType type, Boolean publicOnly, Boolean noCheck, Boolean& canBeCached, RuntimeMethodHandle& ctor, Boolean& bNeedSecurityCheck) +0
   System.RuntimeType.CreateInstanceSlow(Boolean publicOnly, Boolean fillCache) +86
   System.RuntimeType.CreateInstanceImpl(Boolean publicOnly, Boolean skipVisibilityChecks, Boolean fillCache) +230
   System.Activator.CreateInstance(Type type, Boolean nonPublic) +67
   System.RuntimeType.CreateInstanceImpl(BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) +1051
   System.Activator.CreateInstance(Type type, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) +111
   System.Web.HttpApplicationFactory.GetSpecialApplicationInstance(IntPtr appContext, HttpContext context) +215
   System.Web.HttpApplicationFactory.FireApplicationOnStart(HttpContext context) +8878568
   System.Web.HttpApplicationFactory.EnsureAppStartCalled(HttpContext context) +136
   System.Web.HttpApplicationFactory.GetApplicationInstance(HttpContext context) +92
   System.Web.HttpRuntime.ProcessRequestInternal(HttpWorkerRequest wr) +289

在 Global.asax 中引发了异常,其中log4net.ILog正在创建一个实例:

public class MvcApplication : System.Web.HttpApplication
{
    private static log4net.ILog log = log4net.LogManager.GetLogger("global.asax");

    public static void RegisterRoutes(RouteCollection routes)
    {
        routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

        routes.MapRoute(
            "Home.aspx",
            "",
            new { action = "Index", controller = "Home" }
        );

该问题不会在测试中发生 - 我们无法重现它。我已经删除了现场网站上的所有文件,并重新上传了它们,以防万一某些东西可能已损坏,但这并没有解决问题。

我相信在 ISP 方面可能发生了一些改变,从而破坏了某些东西。

关于如何解决这个问题的任何线索?

4

2 回答 2

0

我有一个类似的问题。在我的情况下,我不小心在 Web.config 中填写了一个布尔字段,因为它不是布尔值。

例如,我的 Web.config 中有这个:

<appender name="XYLogger" type="log4net.Appender.RollingFileAppender">
    <file value="App_Data\logging\xymaps.log" />
    <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
    <appendToFile value="some-file-name"/>
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="2" />
    <maximumFileSize value="2MB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d [%t] %-tp %c %m%n" />
    </layout>
</appender>

我误认为<appendToFile>是指定记录器应附加到的文件名的标记。相反,它应该已经阅读<appendToFile value="true" />。因此,如果其他人遇到此问题,我会建议他们仔细检查其 Web.config 中是否存在值不正确的布尔字段。

于 2014-06-06T16:37:00.080 回答
-1

LogManager.GetLogger() 需要用于记录的类的名称,而不是文件名 Global.asax。请仅使用“全局”作为 LogManager.GetLogger() 的参数。

于 2011-02-22T07:45:46.750 回答