Asp.net mvc ASP.NET MVC信号器重新连接并协商引发System.OutOfMemoryException
我有一个ASP.NET MVC应用程序正在处理Web Garden配置。应用程序池标识设置为自定义域帐户(具有本地管理员权限)。应用程序池有4个工作进程。会话状态模式使用在同一台机器(而不是远程机器)上运行的ASP.NET状态服务设置为serverState 关于signalr,在尝试重新连接和协商时,我注意到事件日志中存在OutOfMemoryException,我无法检测到发生了什么。我们将非常感谢您的帮助 下面错误中的一些文本是西班牙语(对不起) 下面是重新连接错误:Asp.net mvc ASP.NET MVC信号器重新连接并协商引发System.OutOfMemoryException,asp.net-mvc,iis,signalr,application-pool,web-garden,Asp.net Mvc,Iis,Signalr,Application Pool,Web Garden,我有一个ASP.NET MVC应用程序正在处理Web Garden配置。应用程序池标识设置为自定义域帐户(具有本地管理员权限)。应用程序池有4个工作进程。会话状态模式使用在同一台机器(而不是远程机器)上运行的ASP.NET状态服务设置为serverState 关于signalr,在尝试重新连接和协商时,我注意到事件日志中存在OutOfMemoryException,我无法检测到发生了什么。我们将非常感谢您的帮助 下面错误中的一些文本是西班牙语(对不起) 下面是重新连接错误: Event code
Event code: 3005
Event message: Excepción no controlada.
Event time: 05/11/2020 13:28:04
Event time (UTC): 05/11/2020 12:28:04
Event ID: 447eb425512c433387a36b70af64f768
Event sequence: 1
Event occurrence: 1
Event detail code: 0
Application information:
Application domain: /LM/W3SVC/2/ROOT-2-132490528843179653
Trust level: Full
Application Virtual Path: /
Application Path: C:\inetpub\wwwroot\MyMVCApp\
Machine name: MyServer
Process information:
Process ID: 1668
Process name: w3wp.exe
Account name: MyDomain\MyAppPoolCustomIdentity
Exception information:
Exception type: InvalidOperationException
Exception message: El método de inicialización Run previo al inicio de la aplicación del tipo WebActivatorEx.ActivationManager produjo una excepción con el siguiente mensaje de error: Se produjo una excepción de tipo 'System.OutOfMemoryException'..
en System.Web.Compilation.BuildManager.InvokePreStartInitMethodsCore(ICollection`1 methods, Func`1 setHostingEnvironmentCultures)
en System.Web.Compilation.BuildManager.InvokePreStartInitMethods(ICollection`1 methods)
en System.Web.Compilation.BuildManager.CallPreStartInitMethods(String preStartInitListPath, Boolean& isRefAssemblyLoaded)
en System.Web.Compilation.BuildManager.ExecutePreAppStart()
en System.Web.Hosting.HostingEnvironment.Initialize(ApplicationManager appManager, IApplicationHost appHost, IConfigMapPathFactory configMapPathFactory, HostingEnvironmentParameters hostingParameters, PolicyLevel policyLevel, Exception appDomainCreationException)
Se produjo una excepción de tipo 'System.OutOfMemoryException'.
en System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
en System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
en System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, RuntimeAssembly reqAssembly, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
en System.Reflection.RuntimeAssembly.InternalLoadFrom(String assemblyFile, Evidence securityEvidence, Byte[] hashValue, AssemblyHashAlgorithm hashAlgorithm, Boolean forIntrospection, Boolean suppressSecurityChecks, StackCrawlMark& stackMark)
en System.Reflection.Assembly.LoadFrom(String assemblyFile)
en WebActivatorEx.ActivationManager.get_Assemblies()
en WebActivatorEx.ActivationManager.RunActivationMethods[T](Boolean designerMode)
en WebActivatorEx.ActivationManager.Run()
Request information:
Request URL: http://my.mvcapp.com/signalr/reconnect?transport=longPolling&clientProtocol=1.5&connectionToken=6Avu6HS5DNT2tKAPHT90nO3u8M2arqOCtaMVIGGiEi/ZsxSM3axZQUBukhn1C0p14qGfoIxy722kR3LhvsZb5Qq6ERwk8z9GA6DI4VGJ8fm8onV8pM79bGp2BTIwaareiiXFYGIWDJxWL7LKux6TwA==&connectionData=[{"name":"wstimerhub"}]
Request path: /signalr/reconnect
User host address: XXX.XX.X.XX
User:
Is authenticated: False
Authentication Type:
Thread account name: MyDomain\MyAppPoolCustomIdentity
Thread information:
Thread ID: 51
Thread account name: MyDomain\MyAppPoolCustomIdentity
Is impersonating: False
Stack trace: en System.Web.Compilation.BuildManager.InvokePreStartInitMethodsCore(ICollection`1 methods, Func`1 setHostingEnvironmentCultures)
en System.Web.Compilation.BuildManager.InvokePreStartInitMethods(ICollection`1 methods)
en System.Web.Compilation.BuildManager.CallPreStartInitMethods(String preStartInitListPath, Boolean& isRefAssemblyLoaded)
en System.Web.Compilation.BuildManager.ExecutePreAppStart()
en System.Web.Hosting.HostingEnvironment.Initialize(ApplicationManager appManager, IApplicationHost appHost, IConfigMapPathFactory configMapPathFactory, HostingEnvironmentParameters hostingParameters, PolicyLevel policyLevel, Exception appDomainCreationException)
Custom event details:
在信号机协商错误(事件id 1309)下方:
您可以使用调试诊断工具捕获在IIS中运行的应用程序的数据,在捕获后生成dmp文件,并使用调试诊断分析来分析文件。然后找到outofmemory的原因。@BruceZhang您能提供下载调试诊断工具的链接吗?我担心使用此工具,因为我需要在生产环境中进行调试,我不知道此工具是否会消耗大量服务器资源(从而影响我的ASP.NET MVC应用程序的性能和响应能力)。您可以从以下链接下载:。它不会消耗大量资源。
Event code: 3005
Event message: Excepción no controlada.
Event time: 05/11/2020 18:09:47
Event time (UTC): 05/11/2020 17:09:47
Event ID: c19a08970c4c44abb969098d601bc6e1
Event sequence: 13649
Event occurrence: 2
Event detail code: 0
Application information:
Application domain: /LM/W3SVC/2/ROOT-4-132490644058804577
Trust level: Full
Application Virtual Path: /
Application Path: C:\inetpub\wwwroot\MyMVCApp\
Machine name: MyServer
Process information:
Process ID: 6936
Process name: w3wp.exe
Account name: MyDomain\MyAppPoolCustomIdentity
Exception information:
Exception type: OutOfMemoryException
Exception message: Se produjo una excepción de tipo 'System.OutOfMemoryException'.
en System.Web.Hosting.IIS7WorkerRequest.ReadRequestHeaders()
en System.Web.Hosting.IIS7WorkerRequest.GetKnownRequestHeader(Int32 index)
en System.Web.HttpWorkerRequest.HasEntityBody()
en System.Web.HttpRequest.GetEncodingFromHeaders()
en System.Web.HttpRequest.get_ContentEncoding()
en System.Web.HttpRequest.get_QueryStringEncoding()
en System.Web.HttpRequest.get_QueryStringText()
en System.Web.HttpRequest.ValidateInputIfRequiredByConfig()
en System.Web.HttpApplication.PipelineStepManager.ValidateHelper(HttpContext context)
Request information:
Request URL: http://my.mvcapp.com/signalr/negotiate?clientProtocol=1.5&connectionData=[{"name":"wstimerhub"}]&_=1604596208232
Request path: /signalr/negotiate
User host address: XXX.XX.XXX.XX
User: MyDomain\OneUser
Is authenticated: True
Authentication Type: Negotiate
Thread account name: MyDomain\MyAppPoolCustomIdentity
Thread information:
Thread ID: 86
Thread account name: MyDomain\MyAppPoolCustomIdentity
Is impersonating: False
Stack trace: en System.Web.Hosting.IIS7WorkerRequest.ReadRequestHeaders()
en System.Web.Hosting.IIS7WorkerRequest.GetKnownRequestHeader(Int32 index)
en System.Web.HttpWorkerRequest.HasEntityBody()
en System.Web.HttpRequest.GetEncodingFromHeaders()
en System.Web.HttpRequest.get_ContentEncoding()
en System.Web.HttpRequest.get_QueryStringEncoding()
en System.Web.HttpRequest.get_QueryStringText()
en System.Web.HttpRequest.ValidateInputIfRequiredByConfig()
en System.Web.HttpApplication.PipelineStepManager.ValidateHelper(HttpContext context)
Custom event details: