ASP.NET MVC Signalr повторно подключается и согласовывает запуск системы.Исключение OutOfMemoryException

#asp.net-mvc #iis #signalr #application-pool #web-garden

#asp.net-mvc #iis #signalr #пул приложений #веб-сад

Вопрос:

У меня есть ASP.NET Приложение MVC, работающее над конфигурацией веб-сада. Идентификатор пула приложений устанавливается на пользовательскую учетную запись домена (с правами локального администратора). Пул приложений имеет 4 рабочих процесса. Режим состояния сеанса устанавливается в состояние сервера с помощью ASP.NET Государственная служба, которая работает на том же компьютере (не удаленном).

Что касается signalr, я заметил исключение OutOfMemoryException в журнале событий при попытке повторного подключения и согласования, и я не могу определить, что происходит. Любая помощь будет высоко оценена.

Некоторые тексты ниже в ошибках на испанском языке (извините).

Ниже ошибка повторного подключения:

 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:inetpubwwwrootMyMVCApp 
    Machine name: MyServer 
 
Process information: 
    Process ID: 1668 
    Process name: w3wp.exe 
    Account name: MyDomainMyAppPoolCustomIdentity 
 
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, Booleanamp; 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, StackCrawlMarkamp; stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
   en System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMarkamp; stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
   en System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, RuntimeAssembly reqAssembly, StackCrawlMarkamp; 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, StackCrawlMarkamp; 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=longPollingamp;clientProtocol=1.5amp;connectionToken=6Avu6HS5DNT2tKAPHT90nO3u8M2arqOCtaMVIGGiEi/ZsxSM3axZQUBukhn1C0p14qGfoIxy722kR3LhvsZb5Qq6ERwk8z9GA6DI4VGJ8fm8onV8pM79bGp2BTIwaareiiXFYGIWDJxWL7LKux6TwA==amp;connectionData=[{"name":"wstimerhub"}] 
    Request path: /signalr/reconnect 
    User host address: XXX.XX.X.XX 
    User:  
    Is authenticated: False 
    Authentication Type:  
    Thread account name: MyDomainMyAppPoolCustomIdentity
 
Thread information: 
    Thread ID: 51 
    Thread account name: MyDomainMyAppPoolCustomIdentity
    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, Booleanamp; 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: 
  

И ниже ошибка signalr negotitate (идентификатор события 1309):

 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:inetpubwwwrootMyMVCApp 
    Machine name: MyServer 
 
Process information: 
    Process ID: 6936 
    Process name: w3wp.exe 
    Account name: MyDomainMyAppPoolCustomIdentity  
 
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.5amp;connectionData=[{"name":"wstimerhub"}]amp;_=1604596208232 
    Request path: /signalr/negotiate 
    User host address: XXX.XX.XXX.XX 
    User: MyDomainOneUser
    Is authenticated: True 
    Authentication Type: Negotiate 
    Thread account name: MyDomainMyAppPoolCustomIdentity  
 
Thread information: 
    Thread ID: 86 
    Thread account name: MyDomainMyAppPoolCustomIdentity 
    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: 
  

Комментарии:

1. Вы можете использовать средство диагностики отладки для сбора данных приложений, запущенных в IIS, генерировать файлы dmp после захвата и использовать анализ отладочной диагностики для анализа файлов. Затем найдите причину outofmemory.

2. @BruceZhang Не могли бы вы предоставить ссылку для загрузки средства диагностики отладки? Я беспокоюсь об использовании этого инструмента, поскольку мне нужно отлаживать в рабочей среде, и я не знаю, потребляет ли этот инструмент много ресурсов сервера (и, следовательно, влияет на производительность и отзывчивость моего ASP.NET Приложение MVC)

3. Вы можете загрузить из этого link:microsoft.com/en-us/download/details.aspx?id=58210 . Это не будет потреблять много ресурсов.